阿里云百炼提供与 OpenAI 兼容的 Batch API,支持以文件方式批量提交任务,系统将异步执行,任务完成或达到最长等待时间时返回结果,费用仅为实时调用的 50%。适用于数据分析、模型评测等对时效性要求不高但需要大批量处理的业务。
如需在控制台操作,请参见批量推理。
工作流程
前提条件
支持通过OpenAI SDK(Python、Node.js)或HTTP API调用 Batch 接口。
获取 API Key:获取并配置 API Key 到环境变量
安装SDK(可选):若使用 SDK 调用,请安装 OpenAI SDK
服务端点
中国内地:
https://dashscope.aliyuncs.com/compatible-mode/v1国际:
https://dashscope-intl.aliyuncs.com/compatible-mode/v1
适用范围
中国内地
支持的模型:
文本生成模型:通义千问 Max、Plus、Flash、Turbo、Long 的稳定版本及其部分
latest版本,以及 QwQ 系列(qwq-plus、qwq-32b-preview)和部分第三方模型(deepseek-r1、deepseek-v3)。多模态模型:通义千问 VL Max、Plus、Flash、OCR的稳定版本及其部分
latest版本,以及通义千问 Omni 模型。文本向量模型:所有版本的 text-embedding 模型。
支持的模型名称清单
文本生成模型
通义千问 Max:qwen3-max、qwen-max、qwen-max-latest
通义千问 Plus:qwen-plus、qwen-plus-latest
通义千问 Flash:qwen-flash
通义千问 Turbo:qwen-turbo、qwen-turbo-latest
通义千问 Long:qwen-long、qwen-long-latest
QwQ:qwq-plus
QwQ-Preview:qwq-32b-preview
第三方模型:deepseek-r1、deepseek-v3
多模态模型
文本向量模型:text-embedding-v1、text-embedding-v2、text-embedding-v3、text-embedding-v4
国际
支持的模型:qwen-max、qwen-plus、qwen-turbo。
快速开始
在处理正式任务前,可使用测试模型batch-test-model进行全链路闭环测试。测试模型会跳过推理过程,直接返回一个固定的成功响应,用于验证 API 调用链路和数据格式是否正确。
测试模型(batch-test-model)的限制:
测试文件需满足输入文件要求,且文件大小不超过 1 MB,行数不超过100行。
并发限制:最大并行任务数 2 个。
费用:测试模型不产生模型推理费用。
第 1 步:准备输入文件
准备一个名为test_model.jsonl的文件,内容如下:
{"custom_id":"1","method":"POST","url":"/v1/chat/ds-test","body":{"model":"batch-test-model","messages":[{"role":"system","content":"You are a helpful assistant."},{"role":"user","content":"你好!有什么可以帮助你的吗?"}]}}
{"custom_id":"2","method":"POST","url":"/v1/chat/ds-test","body":{"model":"batch-test-model","messages":[{"role":"system","content":"You are a helpful assistant."},{"role":"user","content":"What is 2+2?"}]}}第 2 步:运行代码
根据使用的编程语言,选择以下示例代码并将其保存在输入文件的同一目录下,然后运行。代码将完成文件上传、创建任务、轮询状态和下载结果的完整流程。
如需调整文件路径或其他参数,请根据实际情况修改代码。
示例代码
OpenAI Python SDK
import os
from pathlib import Path
from openai import OpenAI
import time
# 初始化客户端
client = OpenAI(
# 若没有配置环境变量,可用阿里云百炼API Key将下行替换为:api_key="sk-xxx",但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
# 新加坡和北京地域的API Key不同。
api_key=os.getenv("DASHSCOPE_API_KEY"),
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
# 注意:切换地域时,API Key也需要对应更换
base_url="https://dashscope.aliyuncs.com/compatible-mode/v1" # 阿里云百炼服务的base_url
)
def upload_file(file_path):
print(f"正在上传包含请求信息的JSONL文件...")
file_object = client.files.create(file=Path(file_path), purpose="batch")
print(f"文件上传成功。得到文件ID: {file_object.id}\n")
return file_object.id
def create_batch_job(input_file_id):
print(f"正在基于文件ID,创建Batch任务...")
# 请注意:此处endpoint参数值需和输入文件中的url字段保持一致.测试模型(batch-test-model)填写/v1/chat/ds-test,Embedding文本向量模型填写/v1/embeddings,其他模型填写/v1/chat/completions
batch = client.batches.create(input_file_id=input_file_id, endpoint="/v1/chat/ds-test", completion_window="24h")
print(f"Batch任务创建完成。 得到Batch任务ID: {batch.id}\n")
return batch.id
def check_job_status(batch_id):
print(f"正在检查Batch任务状态...")
batch = client.batches.retrieve(batch_id=batch_id)
print(f"Batch任务状态: {batch.status}\n")
return batch.status
def get_output_id(batch_id):
print(f"正在获取Batch任务中执行成功请求的输出文件ID...")
batch = client.batches.retrieve(batch_id=batch_id)
print(f"输出文件ID: {batch.output_file_id}\n")
return batch.output_file_id
def get_error_id(batch_id):
print(f"正在获取Batch任务中执行错误请求的输出文件ID...")
batch = client.batches.retrieve(batch_id=batch_id)
print(f"错误文件ID: {batch.error_file_id}\n")
return batch.error_file_id
def download_results(output_file_id, output_file_path):
print(f"正在打印并下载Batch任务的请求成功结果...")
content = client.files.content(output_file_id)
# 打印部分内容以供测试
print(f"打印请求成功结果的前1000个字符内容: {content.text[:1000]}...\n")
# 保存结果文件至本地
content.write_to_file(output_file_path)
print(f"完整的输出结果已保存至本地输出文件result.jsonl\n")
def download_errors(error_file_id, error_file_path):
print(f"正在打印并下载Batch任务的请求失败信息...")
content = client.files.content(error_file_id)
# 打印部分内容以供测试
print(f"打印请求失败信息的前1000个字符内容: {content.text[:1000]}...\n")
# 保存错误信息文件至本地
content.write_to_file(error_file_path)
print(f"完整的请求失败信息已保存至本地错误文件error.jsonl\n")
def main():
# 文件路径
input_file_path = "test_model.jsonl" # 可替换为您的输入文件路径
output_file_path = "result.jsonl" # 可替换为您的输出文件路径
error_file_path = "error.jsonl" # 可替换为您的错误文件路径
try:
# Step 1: 上传包含请求信息的JSONL文件,得到输入文件ID,如果您需要输入OSS文件,可将下行替换为:input_file_id = "实际的OSS文件URL或资源标识符"
input_file_id = upload_file(input_file_path)
# Step 2: 基于输入文件ID,创建Batch任务
batch_id = create_batch_job(input_file_id)
# Step 3: 检查Batch任务状态直到结束
status = ""
while status not in ["completed", "failed", "expired", "cancelled"]:
status = check_job_status(batch_id)
print(f"等待任务完成...")
time.sleep(10) # 等待10秒后再次查询状态
# 如果任务失败,则打印错误信息并退出
if status == "failed":
batch = client.batches.retrieve(batch_id)
print(f"Batch任务失败。错误信息为:{batch.errors}\n")
print(f"参见错误码文档: https://help.aliyun.com/zh/model-studio/developer-reference/error-code")
return
# Step 4: 下载结果:如果输出文件ID不为空,则打印请求成功结果的前1000个字符内容,并下载完整的请求成功结果到本地输出文件;
# 如果错误文件ID不为空,则打印请求失败信息的前1000个字符内容,并下载完整的请求失败信息到本地错误文件.
output_file_id = get_output_id(batch_id)
if output_file_id:
download_results(output_file_id, output_file_path)
error_file_id = get_error_id(batch_id)
if error_file_id:
download_errors(error_file_id, error_file_path)
print(f"参见错误码文档: https://help.aliyun.com/zh/model-studio/developer-reference/error-code")
except Exception as e:
print(f"An error occurred: {e}")
print(f"参见错误码文档: https://help.aliyun.com/zh/model-studio/developer-reference/error-code")
if __name__ == "__main__":
main()OpenAI Node.js SDK
/**
* 阿里云百炼 Batch API 测试 - 使用 OpenAI Node.js SDK
*
* 安装依赖:npm install openai
* 运行:node test-nodejs.js
*/
const OpenAI = require('openai');
const fs = require('fs');
// 北京地域的 Base URL
const BASE_URL = 'https://dashscope.aliyuncs.com/compatible-mode/v1';
// 如果使用新加坡地域,使用以下 URL:
// const BASE_URL = 'https://dashscope-intl.aliyuncs.com/compatible-mode/v1';
const apiKey = process.env.DASHSCOPE_API_KEY;
if (!apiKey) {
console.error('错误: 请设置环境变量 DASHSCOPE_API_KEY');
process.exit(1);
}
// 初始化客户端
const client = new OpenAI({
apiKey: apiKey,
baseURL: BASE_URL
});
async function sleep(ms) {
return new Promise(resolve => setTimeout(resolve, ms));
}
async function main() {
try {
console.log('=== 开始 Batch API 测试 ===\n');
// Step 1: 上传文件
console.log('步骤 1: 上传包含请求信息的 JSONL 文件...');
const fileStream = fs.createReadStream('test_model.jsonl');
const fileObject = await client.files.create({
file: fileStream,
purpose: 'batch'
});
const fileId = fileObject.id;
console.log(`✓ 文件上传成功,文件ID: ${fileId}\n`);
// Step 2: 创建 Batch 任务
console.log('步骤 2: 创建 Batch 任务...');
const batch = await client.batches.create({
input_file_id: fileId,
endpoint: '/v1/chat/ds-test', // 测试模型使用 /v1/chat/ds-test
completion_window: '24h'
});
const batchId = batch.id;
console.log(`✓ Batch 任务创建成功,任务ID: ${batchId}\n`);
// Step 3: 轮询任务状态
console.log('步骤 3: 等待任务完成...');
let status = batch.status;
let pollCount = 0;
let latestBatch = batch;
while (!['completed', 'failed', 'expired', 'cancelled'].includes(status)) {
await sleep(10000); // 等待 10 秒
latestBatch = await client.batches.retrieve(batchId);
status = latestBatch.status;
pollCount++;
console.log(` [${pollCount}] 任务状态: ${status}`);
}
console.log(`\n✓ 任务已完成,最终状态: ${status}\n`);
// Step 4: 处理结果
if (status === 'completed') {
console.log('步骤 4: 下载结果文件...');
// 下载成功结果
const outputFileId = latestBatch.output_file_id;
if (outputFileId) {
console.log(` 输出文件ID: ${outputFileId}`);
const content = await client.files.content(outputFileId);
const text = await content.text();
console.log('\n--- 成功结果(前 500 字符)---');
console.log(text.substring(0, Math.min(500, text.length)));
console.log('...\n');
}
// 下载错误文件(如有)
const errorFileId = latestBatch.error_file_id;
if (errorFileId) {
console.log(` 错误文件ID: ${errorFileId}`);
const errorContent = await client.files.content(errorFileId);
const errorText = await errorContent.text();
console.log('\n--- 错误信息 ---');
console.log(errorText);
}
console.log('\n=== 测试成功完成 ===');
} else if (status === 'failed') {
console.error('\n✗ Batch 任务失败');
if (latestBatch.errors) {
console.error('错误信息:', latestBatch.errors);
}
console.error('\n请参考错误码文档: https://help.aliyun.com/zh/model-studio/developer-reference/error-code');
} else {
console.log(`\n任务状态: ${status}`);
}
} catch (error) {
console.error('发生错误:', error.message);
console.error(error);
}
}
main();Java(HTTP)
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.Scanner;
/**
* 阿里云百炼 Batch API 测试 - 使用 HTTP API 调用
*
* 前置条件:
* 1. 确保已经设置环境变量 DASHSCOPE_API_KEY
* 2. 准备好测试文件 test_model.jsonl(在项目根目录)
*
* 地域配置说明:
* - 北京地域:https://dashscope.aliyuncs.com/compatible-mode/v1
* - 新加坡地域:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
*/
public class BatchAPITest {
// 北京地域的 Base URL(默认)
private static final String BASE_URL = "https://dashscope.aliyuncs.com/compatible-mode/v1";
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// private static final String BASE_URL = "https://dashscope-intl.aliyuncs.com/compatible-mode/v1";
private static String API_KEY;
public static void main(String[] args) throws Exception {
// 从环境变量获取 API Key
API_KEY = System.getenv("DASHSCOPE_API_KEY");
if (API_KEY == null || API_KEY.isEmpty()) {
System.err.println("错误: 请设置环境变量 DASHSCOPE_API_KEY");
System.exit(1);
}
System.out.println("=== 开始 Batch API 测试 ===\n");
try {
// Step 1: 上传文件
System.out.println("步骤 1: 上传包含请求信息的 JSONL 文件...");
String fileId = uploadFile("test_model.jsonl");
System.out.println("✓ 文件上传成功,文件ID: " + fileId + "\n");
// Step 2: 创建 Batch 任务
System.out.println("步骤 2: 创建 Batch 任务...");
String batchId = createBatch(fileId);
System.out.println("✓ Batch 任务创建成功,任务ID: " + batchId + "\n");
// Step 3: 轮询任务状态
System.out.println("步骤 3: 等待任务完成...");
String status = "";
int pollCount = 0;
while (!isTerminalStatus(status)) {
Thread.sleep(10000); // 等待 10 秒
String batchInfo = getBatch(batchId);
status = parseStatus(batchInfo);
pollCount++;
System.out.println(" [" + pollCount + "] 任务状态: " + status);
// Step 4: 如果完成,下载结果
if ("completed".equals(status)) {
System.out.println("\n✓ 任务已完成!\n");
System.out.println("步骤 4: 下载结果文件...");
String outputFileId = parseOutputFileId(batchInfo);
if (outputFileId != null && !outputFileId.isEmpty()) {
System.out.println(" 输出文件ID: " + outputFileId);
String content = getFileContent(outputFileId);
System.out.println("\n--- 成功结果(前 500 字符)---");
System.out.println(content.substring(0, Math.min(500, content.length())));
System.out.println("...\n");
}
String errorFileId = parseErrorFileId(batchInfo);
if (errorFileId != null && !errorFileId.isEmpty() && !"null".equals(errorFileId)) {
System.out.println(" 错误文件ID: " + errorFileId);
String errorContent = getFileContent(errorFileId);
System.out.println("\n--- 错误信息 ---");
System.out.println(errorContent);
}
System.out.println("\n=== 测试成功完成 ===");
break;
} else if ("failed".equals(status)) {
System.err.println("\n✗ Batch 任务失败");
System.err.println("任务信息: " + batchInfo);
System.err.println("\n请参考错误码文档: https://help.aliyun.com/zh/model-studio/developer-reference/error-code");
break;
} else if ("expired".equals(status) || "cancelled".equals(status)) {
System.out.println("\n任务状态: " + status);
break;
}
}
} catch (Exception e) {
System.err.println("发生错误: " + e.getMessage());
e.printStackTrace();
}
}
/**
* 上传文件
*/
private static String uploadFile(String filePath) throws Exception {
String boundary = "----WebKitFormBoundary" + System.currentTimeMillis();
URL url = new URL(BASE_URL + "/files");
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setDoOutput(true);
conn.setRequestMethod("POST");
conn.setRequestProperty("Authorization", "Bearer " + API_KEY);
conn.setRequestProperty("Content-Type", "multipart/form-data; boundary=" + boundary);
try (DataOutputStream out = new DataOutputStream(conn.getOutputStream())) {
// 添加 purpose 字段
out.writeBytes("--" + boundary + "\r\n");
out.writeBytes("Content-Disposition: form-data; name=\"purpose\"\r\n\r\n");
out.writeBytes("batch\r\n");
// 添加文件
out.writeBytes("--" + boundary + "\r\n");
out.writeBytes("Content-Disposition: form-data; name=\"file\"; filename=\"" + filePath + "\"\r\n");
out.writeBytes("Content-Type: application/octet-stream\r\n\r\n");
byte[] fileBytes = Files.readAllBytes(Paths.get(filePath));
out.write(fileBytes);
out.writeBytes("\r\n");
out.writeBytes("--" + boundary + "--\r\n");
}
String response = readResponse(conn);
return parseField(response, "\"id\":\s*\"([^\"]+)\"");
}
/**
* 创建 Batch 任务
*/
private static String createBatch(String fileId) throws Exception {
String jsonBody = String.format(
"{\"input_file_id\":\"%s\",\"endpoint\":\"/v1/chat/ds-test\",\"completion_window\":\"24h\"}",
fileId
);
String response = sendRequest("POST", "/batches", jsonBody);
return parseField(response, "\"id\":\s*\"([^\"]+)\"");
}
/**
* 获取 Batch 任务信息
*/
private static String getBatch(String batchId) throws Exception {
return sendRequest("GET", "/batches/" + batchId, null);
}
/**
* 获取文件内容
*/
private static String getFileContent(String fileId) throws Exception {
return sendRequest("GET", "/files/" + fileId + "/content", null);
}
/**
* 发送 HTTP 请求
*/
private static String sendRequest(String method, String path, String jsonBody) throws Exception {
URL url = new URL(BASE_URL + path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod(method);
conn.setRequestProperty("Authorization", "Bearer " + API_KEY);
if (jsonBody != null) {
conn.setDoOutput(true);
conn.setRequestProperty("Content-Type", "application/json");
try (OutputStream os = conn.getOutputStream()) {
os.write(jsonBody.getBytes("UTF-8"));
}
}
return readResponse(conn);
}
/**
* 读取响应
*/
private static String readResponse(HttpURLConnection conn) throws Exception {
int responseCode = conn.getResponseCode();
InputStream is = (responseCode < 400) ? conn.getInputStream() : conn.getErrorStream();
try (Scanner scanner = new Scanner(is, "UTF-8").useDelimiter("\\A")) {
return scanner.hasNext() ? scanner.next() : "";
}
}
/**
* 解析 JSON 字段(简单实现)
*/
private static String parseField(String json, String regex) {
java.util.regex.Pattern pattern = java.util.regex.Pattern.compile(regex);
java.util.regex.Matcher matcher = pattern.matcher(json);
return matcher.find() ? matcher.group(1) : null;
}
private static String parseStatus(String json) {
return parseField(json, "\"status\":\s*\"([^\"]+)\"");
}
private static String parseOutputFileId(String json) {
return parseField(json, "\"output_file_id\":\s*\"([^\"]+)\"");
}
private static String parseErrorFileId(String json) {
return parseField(json, "\"error_file_id\":\s*\"([^\"]+)\"");
}
/**
* 判断是否为终止状态
*/
private static boolean isTerminalStatus(String status) {
return "completed".equals(status)
|| "failed".equals(status)
|| "expired".equals(status)
|| "cancelled".equals(status);
}
}curl (HTTP)
#!/bin/bash
# 阿里云百炼 Batch API 测试 - 使用 curl
#
# 前置条件:
# 1. 确保已经设置环境变量 DASHSCOPE_API_KEY
# 2. 准备好测试文件 test_model.jsonl(在当前目录)
#
# 地域配置说明:
# - 北京地域:https://dashscope.aliyuncs.com/compatible-mode/v1
# - 新加坡地域:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
API_KEY="${DASHSCOPE_API_KEY}"
BASE_URL="https://dashscope.aliyuncs.com/compatible-mode/v1"
# 如果使用新加坡地域,请将 BASE_URL 替换为:
# BASE_URL="https://dashscope-intl.aliyuncs.com/compatible-mode/v1"
# 检查 API Key
if [ -z "$API_KEY" ]; then
echo "错误: 请设置环境变量 DASHSCOPE_API_KEY"
exit 1
fi
echo "=== 开始 Batch API 测试 ==="
echo ""
# Step 1: 上传文件
echo "步骤 1: 上传包含请求信息的 JSONL 文件..."
UPLOAD_RESPONSE=$(curl -s -X POST "${BASE_URL}/files" \
-H "Authorization: Bearer ${API_KEY}" \
-F 'file=@test_model.jsonl' \
-F 'purpose=batch')
FILE_ID=$(echo $UPLOAD_RESPONSE | grep -o '"id":"[^"]*"' | head -1 | cut -d'"' -f4)
echo "✓ 文件上传成功,文件ID: ${FILE_ID}"
echo ""
# Step 2: 创建 Batch 任务
echo "步骤 2: 创建 Batch 任务..."
BATCH_RESPONSE=$(curl -s -X POST "${BASE_URL}/batches" \
-H "Authorization: Bearer ${API_KEY}" \
-H "Content-Type: application/json" \
-d "{\"input_file_id\":\"${FILE_ID}\",\"endpoint\":\"/v1/chat/ds-test\",\"completion_window\":\"24h\"}")
BATCH_ID=$(echo $BATCH_RESPONSE | grep -o '"id":"[^"]*"' | head -1 | cut -d'"' -f4)
echo "✓ Batch 任务创建成功,任务ID: ${BATCH_ID}"
echo ""
# Step 3: 轮询任务状态
echo "步骤 3: 等待任务完成..."
STATUS=""
POLL_COUNT=0
while [[ "$STATUS" != "completed" && "$STATUS" != "failed" && "$STATUS" != "expired" && "$STATUS" != "cancelled" ]]; do
sleep 10
BATCH_INFO=$(curl -s -X GET "${BASE_URL}/batches/${BATCH_ID}" \
-H "Authorization: Bearer ${API_KEY}")
STATUS=$(echo $BATCH_INFO | grep -o '"status":"[^"]*"' | cut -d'"' -f4)
POLL_COUNT=$((POLL_COUNT + 1))
echo " [${POLL_COUNT}] 任务状态: ${STATUS}"
done
echo ""
echo "✓ 任务已完成,最终状态: ${STATUS}"
echo ""
# Step 4: 下载结果
if [[ "$STATUS" == "completed" ]]; then
echo "步骤 4: 下载结果文件..."
OUTPUT_FILE_ID=$(echo $BATCH_INFO | grep -o '"output_file_id":"[^"]*"' | cut -d'"' -f4)
if [[ -n "$OUTPUT_FILE_ID" && "$OUTPUT_FILE_ID" != "null" ]]; then
echo " 输出文件ID: ${OUTPUT_FILE_ID}"
RESULT_CONTENT=$(curl -s -X GET "${BASE_URL}/files/${OUTPUT_FILE_ID}/content" \
-H "Authorization: Bearer ${API_KEY}")
echo ""
echo "--- 成功结果(前 500 字符)---"
echo "${RESULT_CONTENT:0:500}"
echo "..."
echo ""
fi
ERROR_FILE_ID=$(echo $BATCH_INFO | grep -o '"error_file_id":"[^"]*"' | cut -d'"' -f4)
if [[ -n "$ERROR_FILE_ID" && "$ERROR_FILE_ID" != "null" ]]; then
echo " 错误文件ID: ${ERROR_FILE_ID}"
ERROR_CONTENT=$(curl -s -X GET "${BASE_URL}/files/${ERROR_FILE_ID}/content" \
-H "Authorization: Bearer ${API_KEY}")
echo ""
echo "--- 错误信息 ---"
echo "${ERROR_CONTENT}"
fi
echo ""
echo "=== 测试成功完成 ==="
elif [[ "$STATUS" == "failed" ]]; then
echo ""
echo "✗ Batch 任务失败"
echo "任务信息: ${BATCH_INFO}"
echo ""
echo "请参考错误码文档: https://help.aliyun.com/zh/model-studio/developer-reference/error-code"
else
echo ""
echo "任务状态: ${STATUS}"
fi第 3 步: 验证测试结果
任务成功完成后,结果文件result.jsonl会包含固定响应{"content":"This is a test result."}:
{"id":"a2b1ae25-21f4-4d9a-8634-99a29926486c","custom_id":"1","response":{"status_code":200,"request_id":"a2b1ae25-21f4-4d9a-8634-99a29926486c","body":{"created":1743562621,"usage":{"completion_tokens":6,"prompt_tokens":20,"total_tokens":26},"model":"batch-test-model","id":"chatcmpl-bca7295b-67c3-4b1f-8239-d78323bb669f","choices":[{"finish_reason":"stop","index":0,"message":{"content":"This is a test result."}}],"object":"chat.completion"}},"error":null}
{"id":"39b74f09-a902-434f-b9ea-2aaaeebc59e0","custom_id":"2","response":{"status_code":200,"request_id":"39b74f09-a902-434f-b9ea-2aaaeebc59e0","body":{"created":1743562621,"usage":{"completion_tokens":6,"prompt_tokens":20,"total_tokens":26},"model":"batch-test-model","id":"chatcmpl-1e32a8ba-2b69-4dc4-be42-e2897eac9e84","choices":[{"finish_reason":"stop","index":0,"message":{"content":"This is a test result."}}],"object":"chat.completion"}},"error":null}执行正式任务
输入文件要求
格式:UTF-8 编码的 JSONL(每行一个独立 JSON 对象)
规模限制:单文件 ≤ 50,000 个请求,且 ≤ 500 MB
单行限制:每个 JSON 对象 ≤ 6 MB,且不超过模型上下文长度
一致性要求:同一文件内所有请求须使用相同模型及思考模式(如适用)
唯一标识:每个请求必须包含文件内唯一的 custom_id 字段,用于结果匹配
示例文件test.jsonl内容:
{"custom_id":"1","method":"POST","url":"/v1/chat/completions","body":{"model":"qwen-plus","messages":[{"role":"system","content":"You are a helpful assistant."},{"role":"user","content":"你好!有什么可以帮助你的吗?"}]}}
{"custom_id":"2","method":"POST","url":"/v1/chat/completions","body":{"model":"qwen-plus","messages":[{"role":"system","content":"You are a helpful assistant."},{"role":"user","content":"What is 2+2?"}]}}JSONL 批量生成工具
使用以下工具可快速生成 JSONL 文件。
1. 修改输入文件
可直接修改用于测试的
test_model.jsonl文件,将 model 参数设置为需要使用的正式模型,并设置 url 字段:模型类型
url
文本生成/多模态模型
/v1/chat/completions文本向量模型
/v1/embeddings或使用上方的“JSONL 批量生成工具”为正式任务生成一个新的文件。关键是确保
model和url字段正确。
2. 修改快速开始的代码
输入文件路径更改为您的文件名
将 endpoint 参数值修改为与输入文件中 url 字段一致的值
3. 运行代码并等待结果
任务成功后,成功的请求结果将保存在本地的 result.jsonl 文件中。如果部分请求失败,错误详情将保存在 error.jsonl 文件中。
成功结果(
output_file_id):每一行对应一个成功的原始请求,包含custom_id和response。{"id":"3a5c39d5-3981-4e4c-97f2-e0e821893f03","custom_id":"req-001","response":{"status_code":200,"request_id":"3a5c39d5-3981-4e4c-97f2-e0e821893f03","body":{"created":1768306034,"usage":{"completion_tokens":654,"prompt_tokens":14,"total_tokens":668},"model":"qwen-plus","id":"chatcmpl-3a5c39d5-3981-4e4c-97f2-e0e821893f03","choices":[{"finish_reason":"stop","index":0,"message":{"role":"assistant","content":"你好!杭州西湖是中国著名的风景名胜区,位于浙江省杭州市西部,因此得名“西湖”。它是中国十大风景名胜之一,也是世界文化遗产(2011年被联合国教科文组织列入《世界遗产名录》),以其秀丽的自然风光与深厚的人文底蕴闻名于世。\n\n### 一、自然景观\n西湖三面环山,一面邻城,湖面面积约6.39平方公里,形似如意,碧波荡漾。湖中被孤山、白堤、苏堤、杨公堤等自然或人工分隔成多个水域,形成“一山二塔三岛三堤”的格局。\n\n主要景点包括:\n- **苏堤春晓**:北宋大文豪苏东坡任杭州知州时主持疏浚西湖,用挖出的淤泥堆筑成堤,后人称为“苏堤”。春天桃红柳绿,景色如画。\n- **断桥残雪**:位于白堤东端,是白蛇传中“断桥相会”的发生地,冬日雪后银装素裹,尤为著名。\n- **雷峰夕照**:雷峰塔在夕阳映照下金光熠熠,曾是“西湖十景”之一。\n- **三潭印月**:湖中小瀛洲上的三座石塔,中秋夜可在塔内点灯,月影、灯光、湖光交相辉映。\n- **平湖秋月**:位于白堤西端,是观赏湖上明月的绝佳地点。\n- **花港观鱼**:以赏花和观鱼著称,园内牡丹、锦鲤相映成趣。\n\n### 二、人文历史\n西湖不仅风景优美,还承载着丰富的历史文化:\n- 自唐宋以来,众多文人墨客如白居易、苏东坡、林逋、杨万里等在此留下诗篇。\n- 白居易曾主持修建“白堤”,疏浚西湖,造福百姓。\n- 西湖周边有众多古迹,如岳王庙(纪念民族英雄岳飞)、灵隐寺(千年古刹)、六和塔、龙井村(中国十大名茶龙井茶的产地)等。\n\n### 三、文化象征\n西湖被誉为“人间天堂”的代表,是中国传统山水美学的典范。它融合了自然美与人文美,体现了“天人合一”的哲学思想。许多诗词、绘画、戏曲都以西湖为题材,成为中国文化的重要符号。\n\n### 四、旅游建议\n- 最佳游览季节:春季(3-5月)桃红柳绿,秋季(9-11月)天高气爽。\n- 推荐方式:步行、骑行(环湖绿道)、乘船游湖。\n- 周边美食:西湖醋鱼、龙井虾仁、东坡肉、片儿川等。\n\n总之,杭州西湖不仅是一处自然美景,更是一座活着的文化博物馆,值得细细品味。如果你有机会到杭州,一定不要错过这个“淡妆浓抹总相宜”的人间仙境。"}}],"object":"chat.completion"}},"error":null} {"id":"628312ba-172c-457d-ba7f-3e5462cc6899","custom_id":"req-002","response":{"status_code":200,"request_id":"628312ba-172c-457d-ba7f-3e5462cc6899","body":{"created":1768306035,"usage":{"completion_tokens":25,"prompt_tokens":18,"total_tokens":43},"model":"qwen-plus","id":"chatcmpl-628312ba-172c-457d-ba7f-3e5462cc6899","choices":[{"finish_reason":"stop","index":0,"message":{"role":"assistant","content":"春风拂柳绿, \n夜雨润花红。 \n鸟语林间闹, \n山川处处同。"}}],"object":"chat.completion"}},"error":null}失败详情(
error_file_id):包含处理失败的请求行信息和错误原因,可参考错误码进行排查。
具体流程
Batch API 的使用流程分为四个步骤:上传文件、创建任务、查询任务状态、下载结果。
如果您的数据已存储在阿里云OSS中,可以跳过上传文件步骤,直接在创建Batch任务时使用OSS文件路径。详情请参见使用 OSS 文件创建 Batch 任务。
1. 上传文件
创建Batch任务前,将符合输入文件格式要求的JSONL文件通过文件上传接口上传,获取file_id。
上传文件,purpose必须是batch。
OpenAI Python SDK
请求示例
import os
from pathlib import Path
from openai import OpenAI
client = OpenAI(
# 若没有配置环境变量,可用阿里云百炼API Key将下行替换为:api_key="sk-xxx"。但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
# 新加坡和北京地域的API Key不同。
api_key=os.getenv("DASHSCOPE_API_KEY"),
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
# 注意:切换地域时,API Key也需要对应更换
base_url="https://dashscope.aliyuncs.com/compatible-mode/v1",
)
# test.jsonl 是一个本地示例文件,purpose必须是batch
file_object = client.files.create(file=Path("test.jsonl"), purpose="batch")
print(file_object.model_dump_json())OpenAI Node.js SDK
请求示例
/**
* 阿里云百炼 Batch API - 上传文件
*
* 若没有配置环境变量,可在代码中硬编码API Key:apiKey: 'sk-xxx'
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 安装依赖:npm install openai
*/
const OpenAI = require('openai');
const fs = require('fs');
// 北京地域配置(默认)
const BASE_URL = 'https://dashscope.aliyuncs.com/compatible-mode/v1';
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// const BASE_URL = 'https://dashscope-intl.aliyuncs.com/compatible-mode/v1';
// 注意:切换地域时,API Key也需要对应更换
const apiKey = process.env.DASHSCOPE_API_KEY;
if (!apiKey) {
console.error('错误: 请设置环境变量 DASHSCOPE_API_KEY');
console.error('或在代码中设置: const apiKey = "sk-xxx";');
process.exit(1);
}
const client = new OpenAI({
apiKey: apiKey,
baseURL: BASE_URL
});
const fileStream = fs.createReadStream('test.jsonl');
const fileObject = await client.files.create({
file: fileStream,
purpose: 'batch'
});
console.log(fileObject.id);Java(HTTP)
请求示例
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.Scanner;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
/**
* 阿里云百炼 Batch API - 上传文件
*
* 若没有配置环境变量,可在代码中硬编码API Key:API_KEY = "sk-xxx"
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 地域配置:
* - 北京地域:https://dashscope.aliyuncs.com/compatible-mode/v1
* - 新加坡地域:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
* 注意:切换地域时,API Key也需要对应更换
*/
public class BatchAPIUploadFile {
// 北京地域配置(默认)
private static final String BASE_URL = "https://dashscope.aliyuncs.com/compatible-mode/v1";
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// private static final String BASE_URL = "https://dashscope-intl.aliyuncs.com/compatible-mode/v1";
// 注意:切换地域时,API Key也需要对应更换
private static String API_KEY;
public static void main(String[] args) throws Exception {
API_KEY = System.getenv("DASHSCOPE_API_KEY");
if (API_KEY == null || API_KEY.isEmpty()) {
System.err.println("错误: 请设置环境变量 DASHSCOPE_API_KEY");
System.err.println("或在代码中设置: API_KEY = \"sk-xxx\";");
System.exit(1);
}
String fileId = uploadFile("test.jsonl");
System.out.println("文件ID: " + fileId);
}
// === 工具方法 ===
private static String uploadFile(String filePath) throws Exception {
String boundary = "----WebKitFormBoundary" + System.currentTimeMillis();
URL url = new URL(BASE_URL + "/files");
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setDoOutput(true);
conn.setRequestMethod("POST");
conn.setRequestProperty("Authorization", "Bearer " + API_KEY);
conn.setRequestProperty("Content-Type", "multipart/form-data; boundary=" + boundary);
try (DataOutputStream out = new DataOutputStream(conn.getOutputStream())) {
// 添加 purpose 字段
out.writeBytes("--" + boundary + "\r\n");
out.writeBytes("Content-Disposition: form-data; name=\"purpose\"\r\n\r\n");
out.writeBytes("batch\r\n");
// 添加文件
out.writeBytes("--" + boundary + "\r\n");
out.writeBytes("Content-Disposition: form-data; name=\"file\"; filename=\"" + filePath + "\"\r\n");
out.writeBytes("Content-Type: application/octet-stream\r\n\r\n");
byte[] fileBytes = Files.readAllBytes(Paths.get(filePath));
out.write(fileBytes);
out.writeBytes("\r\n");
out.writeBytes("--" + boundary + "--\r\n");
}
String response = readResponse(conn);
return parseField(response, "\"id\":\\s*\"([^\"]+)\"");
}
private static String readResponse(HttpURLConnection conn) throws Exception {
int responseCode = conn.getResponseCode();
InputStream is = (responseCode < 400) ? conn.getInputStream() : conn.getErrorStream();
try (Scanner scanner = new Scanner(is, "UTF-8").useDelimiter("\\A")) {
return scanner.hasNext() ? scanner.next() : "";
}
}
private static String parseField(String json, String regex) {
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(json);
return matcher.find() ? matcher.group(1) : null;
}
}curl(HTTP)
请求示例
# ======= 重要提示 =======
# 新加坡和北京地域的API Key不同。
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1/files
# === 执行时请删除该注释 ===
curl -X POST https://dashscope.aliyuncs.com/compatible-mode/v1/files \
-H "Authorization: Bearer $DASHSCOPE_API_KEY" \
--form 'file=@"test.jsonl"' \
--form 'purpose="batch"'返回示例
{
"id": "file-batch-xxx",
"bytes": 437,
"created_at": 1742304153,
"filename": "test.jsonl",
"object": "file",
"purpose": "batch",
"status": "processed",
"status_details": null
}2. 创建 Batch 任务
使用上传文件返回的文件 id或 OSS 路径 创建 Batch 任务。
OpenAI Python SDK
请求示例
import os
from openai import OpenAI
client = OpenAI(
# 若没有配置环境变量,可用阿里云百炼API Key将下行替换为:api_key="sk-xxx"。但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
# 新加坡和北京地域的API Key不同。
api_key=os.getenv("DASHSCOPE_API_KEY"),
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
# 注意:切换地域时,API Key也需要对应更换
base_url="https://dashscope.aliyuncs.com/compatible-mode/v1",
)
batch = client.batches.create(
input_file_id="file-batch-xxx", # 上传文件返回的id或OSS文件URL或OSS文件资源标识符
endpoint="/v1/chat/completions", # 测试模型batch-test-model填写/v1/chat/ds-test,文本向量模型填写/v1/embeddings,文本生成/多模态模型填写/v1/chat/completions
completion_window="24h",
metadata={'ds_name':"任务名称",'ds_description':'任务描述'} # metadata数据,非必填字段,用于创建任务名称、描述
)
print(batch)OpenAI Node.js SDK
请求示例
/**
* 阿里云百炼 Batch API - 创建Batch任务
*
* 若没有配置环境变量,可在代码中硬编码API Key:apiKey: 'sk-xxx'
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 安装依赖:npm install openai
*/
const OpenAI = require('openai');
// 北京地域配置(默认)
const BASE_URL = 'https://dashscope.aliyuncs.com/compatible-mode/v1';
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// const BASE_URL = 'https://dashscope-intl.aliyuncs.com/compatible-mode/v1';
// 注意:切换地域时,API Key也需要对应更换
const apiKey = process.env.DASHSCOPE_API_KEY;
if (!apiKey) {
console.error('错误: 请设置环境变量 DASHSCOPE_API_KEY');
console.error('或在代码中设置: const apiKey = "sk-xxx";');
process.exit(1);
}
const client = new OpenAI({
apiKey: apiKey,
baseURL: BASE_URL
});
const batch = await client.batches.create({
input_file_id: 'file-batch-xxx',
endpoint: '/v1/chat/completions',
completion_window: '24h',
metadata: {'ds_name': '任务名称', 'ds_description': '任务描述'}
});
console.log(batch.id);Java(HTTP)
请求示例
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.Scanner;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
/**
* 阿里云百炼 Batch API - 创建Batch任务
*
* 若没有配置环境变量,可在代码中硬编码API Key:API_KEY = "sk-xxx"
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 地域配置:
* - 北京地域:https://dashscope.aliyuncs.com/compatible-mode/v1
* - 新加坡地域:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
* 注意:切换地域时,API Key也需要对应更换
*/
public class BatchAPICreateBatch {
// 北京地域配置(默认)
private static final String BASE_URL = "https://dashscope.aliyuncs.com/compatible-mode/v1";
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// private static final String BASE_URL = "https://dashscope-intl.aliyuncs.com/compatible-mode/v1";
// 注意:切换地域时,API Key也需要对应更换
private static String API_KEY;
public static void main(String[] args) throws Exception {
API_KEY = System.getenv("DASHSCOPE_API_KEY");
if (API_KEY == null || API_KEY.isEmpty()) {
System.err.println("错误: 请设置环境变量 DASHSCOPE_API_KEY");
System.err.println("或在代码中设置: API_KEY = \"sk-xxx\";");
System.exit(1);
}
String jsonBody = "{\"input_file_id\":\"file-batch-xxx\",\"endpoint\":\"/v1/chat/completions\",\"completion_window\":\"24h\",\"metadata\":{\"ds_name\":\"任务名称\",\"ds_description\":\"任务描述\"}}";
String response = sendRequest("POST", "/batches", jsonBody);
String batchId = parseField(response, "\"id\":\\s*\"([^\"]+)\"");
System.out.println("Batch任务ID: " + batchId);
}
// === 工具方法 ===
private static String sendRequest(String method, String path, String jsonBody) throws Exception {
URL url = new URL(BASE_URL + path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod(method);
conn.setRequestProperty("Authorization", "Bearer " + API_KEY);
if (jsonBody != null) {
conn.setDoOutput(true);
conn.setRequestProperty("Content-Type", "application/json");
try (OutputStream os = conn.getOutputStream()) {
os.write(jsonBody.getBytes("UTF-8"));
}
}
return readResponse(conn);
}
private static String readResponse(HttpURLConnection conn) throws Exception {
int responseCode = conn.getResponseCode();
InputStream is = (responseCode < 400) ? conn.getInputStream() : conn.getErrorStream();
try (Scanner scanner = new Scanner(is, "UTF-8").useDelimiter("\\A")) {
return scanner.hasNext() ? scanner.next() : "";
}
}
private static String parseField(String json, String regex) {
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(json);
return matcher.find() ? matcher.group(1) : null;
}
}curl(HTTP)
请求示例
# ======= 重要提示 =======
# 新加坡和北京地域的API Key不同。
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1/batches
# === 执行时请删除该注释 ===
curl -X POST https://dashscope.aliyuncs.com/compatible-mode/v1/batches \
-H "Authorization: Bearer $DASHSCOPE_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"input_file_id": "file-batch-xxx",
"endpoint": "/v1/chat/completions",
"completion_window": "24h",
"metadata":{"ds_name":"任务名称","ds_description":"任务描述"}
}'输入参数
字段 | 类型 | 传参 方式 | 必选 | 描述 |
input_file_id | String | Body | 是 | 用于指定文件ID、OSS文件URL或OSS文件资源标识符,作为Batch任务的输入文件。您可以通过以下任一方式提供此参数:
|
endpoint | String | Body | 是 | 访问路径,需和输入文件中的url字段保持一致。
|
completion_window | String | Body | 是 | 等待时间,支持最短等待时间24h,最长等待时间336h,仅支持整数。 支持"h"和"d"两个单位,如"24h"或"14d"。 |
metadata | Map | Body | 否 | 任务扩展元数据,以键值对形式附加信息。 |
metadata.ds_name | String | Body | 否 | 任务名称。 示例: 限制:长度不超过100个字符。 若重复定义该字段,以最后一次传入的值为准。 |
metadata.ds_description | String | Body | 否 | 任务描述。 示例: 限制:长度不超过200个字符。 若重复定义该字段,以最后一次传入的值为准。 |
返回示例
{
"id": "batch_xxx",
"object": "batch",
"endpoint": "/v1/chat/completions",
"errors": null,
"input_file_id": "file-batch-xxx",
"completion_window": "24h",
"status": "validating",
"output_file_id": null,
"error_file_id": null,
"created_at": 1742367779,
"in_progress_at": null,
"expires_at": null,
"finalizing_at": null,
"completed_at": null,
"failed_at": null,
"expired_at": null,
"cancelling_at": null,
"cancelled_at": null,
"request_counts": {
"total": 0,
"completed": 0,
"failed": 0
},
"metadata": {
"ds_name": "任务名称",
"ds_description": "任务描述"
}
}返回参数
字段 | 类型 | 描述 |
id | String | 本次创建的Batch任务 ID。 |
object | String | 对象类型,固定值 |
endpoint | String | 访问路径。 |
errors | Map | 错误信息。 |
input_file_id | String | 文件ID或OSS文件 URL或OSS文件资源标识符。 |
completion_window | String | 等待时间,支持最短等待时间24h,最长等待时间336h,仅支持整数。 支持"h"和"d"两个单位,如"24h"或"14d"。 |
status | String | 任务状态,包括validating、failed、in_progress、finalizing、completed、expired、cancelling、cancelled。 |
output_file_id | String | 执行成功请求的输出文件id。 |
error_file_id | String | 执行错误请求的输出文件id。 |
created_at | Integer | 任务创建的Unix 时间戳(秒)。 |
in_progress_at | Integer | 任务开始运行的Unix时间戳(秒)。 |
expires_at | Integer | 任务开始超时的时间戳(秒)。 |
finalizing_at | Integer | 任务最后开始时间戳(秒)。 |
completed_at | Integer | 任务完成的时间戳(秒)。 |
failed_at | Integer | 任务失败的时间戳(秒)。 |
expired_at | Integer | 任务超时的时间戳(秒)。 |
cancelling_at | Integer | 任务设置为取消中的时间戳(秒)。 |
cancelled_at | Integer | 任务取消的时间戳(秒)。 |
request_counts | Map | 不同状态的请求数量。 |
metadata | Map | 附加信息,键值对。 |
metadata.ds_name | String | 当前任务的任务名称。 |
metadata.ds_description | String | 当前任务的任务描述。 |
3. 查询与管理 Batch 任务
任务创建后,您可以通过以下接口查询其状态、列出历史任务或取消正在进行的任务。
查询指定任务状态
通过传入 Batch 任务 ID,来查询指定 Batch 任务的信息。当前仅支持查询 30 天之内创建的 Batch 任务。
OpenAI Python SDK
请求示例
import os
from openai import OpenAI
client = OpenAI(
# 若没有配置环境变量,可用阿里云百炼API Key将下行替换为:api_key="sk-xxx"。但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
# 新加坡和北京地域的API Key不同。
api_key=os.getenv("DASHSCOPE_API_KEY"),
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
# 注意:切换地域时,API Key也需要对应更换
base_url="https://dashscope.aliyuncs.com/compatible-mode/v1",
)
batch = client.batches.retrieve("batch_id") # 将batch_id替换为Batch任务的id
print(batch)OpenAI Node.js SDK
请求示例
/**
* 阿里云百炼 Batch API - 查询单个任务
*
* 若没有配置环境变量,可在代码中硬编码API Key:apiKey: 'sk-xxx'
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 安装依赖:npm install openai
*/
const OpenAI = require('openai');
// 北京地域配置(默认)
const BASE_URL = 'https://dashscope.aliyuncs.com/compatible-mode/v1';
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// const BASE_URL = 'https://dashscope-intl.aliyuncs.com/compatible-mode/v1';
// 注意:切换地域时,API Key也需要对应更换
const apiKey = process.env.DASHSCOPE_API_KEY;
if (!apiKey) {
console.error('错误: 请设置环境变量 DASHSCOPE_API_KEY');
console.error('或在代码中设置: const apiKey = "sk-xxx";');
process.exit(1);
}
const client = new OpenAI({
apiKey: apiKey,
baseURL: BASE_URL
});
const batch = await client.batches.retrieve('batch_id');
console.log(batch.status);Java(HTTP)
请求示例
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.Scanner;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
/**
* 阿里云百炼 Batch API - 查询单个任务
*
* 若没有配置环境变量,可在代码中硬编码API Key:API_KEY = "sk-xxx"
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 地域配置:
* - 北京地域:https://dashscope.aliyuncs.com/compatible-mode/v1
* - 新加坡地域:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
* 注意:切换地域时,API Key也需要对应更换
*/
public class BatchAPIRetrieveBatch {
// 北京地域配置(默认)
private static final String BASE_URL = "https://dashscope.aliyuncs.com/compatible-mode/v1";
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// private static final String BASE_URL = "https://dashscope-intl.aliyuncs.com/compatible-mode/v1";
// 注意:切换地域时,API Key也需要对应更换
private static String API_KEY;
public static void main(String[] args) throws Exception {
API_KEY = System.getenv("DASHSCOPE_API_KEY");
if (API_KEY == null || API_KEY.isEmpty()) {
System.err.println("错误: 请设置环境变量 DASHSCOPE_API_KEY");
System.err.println("或在代码中设置: API_KEY = \"sk-xxx\";");
System.exit(1);
}
String batchInfo = sendRequest("GET", "/batches/batch_id", null);
String status = parseField(batchInfo, "\"status\":\\s*\"([^\"]+)\"");
System.out.println("任务状态: " + status);
}
// === 工具方法 ===
private static String sendRequest(String method, String path, String jsonBody) throws Exception {
URL url = new URL(BASE_URL + path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod(method);
conn.setRequestProperty("Authorization", "Bearer " + API_KEY);
if (jsonBody != null) {
conn.setDoOutput(true);
conn.setRequestProperty("Content-Type", "application/json");
try (OutputStream os = conn.getOutputStream()) {
os.write(jsonBody.getBytes("UTF-8"));
}
}
return readResponse(conn);
}
private static String readResponse(HttpURLConnection conn) throws Exception {
int responseCode = conn.getResponseCode();
InputStream is = (responseCode < 400) ? conn.getInputStream() : conn.getErrorStream();
try (Scanner scanner = new Scanner(is, "UTF-8").useDelimiter("\\A")) {
return scanner.hasNext() ? scanner.next() : "";
}
}
private static String parseField(String json, String regex) {
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(json);
return matcher.find() ? matcher.group(1) : null;
}
}curl(HTTP)
请求示例
# ======= 重要提示 =======
# 新加坡和北京地域的API Key不同。
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1/batches/batch_id
# === 执行时请删除该注释 ===
curl --request GET 'https://dashscope.aliyuncs.com/compatible-mode/v1/batches/batch_id' \
-H "Authorization: Bearer $DASHSCOPE_API_KEY"返回示例
查询成功后返回 Batch 任务的详细信息。以下是一个 completed 状态的返回示例:
{
"id": "batch_abc123",
"object": "batch",
"endpoint": "/v1/chat/completions",
"errors": null,
"input_file_id": "file-abc123",
"completion_window": "24h",
"status": "completed",
"output_file_id": "file-batch_output-xyz789",
"error_file_id": "file-batch_error-xyz789",
"created_at": 1711402400,
"in_progress_at": 1711402450,
"expires_at": 1711488800,
"finalizing_at": 1711405000,
"completed_at": 1711406000,
"failed_at": null,
"expired_at": null,
"cancelling_at": null,
"cancelled_at": null,
"request_counts": {
"total": 100,
"completed": 95,
"failed": 5
},
"metadata": {
"customer_id": "user_123456789",
"batch_description": "Nightly eval job"
}
}返回的 JSON 对象包含 Batch 任务的完整信息,包括任务状态、结果文件 ID、请求统计等。字段详细说明见下表。
字段 | 类型 | 描述 |
id | String | Batch任务ID。 |
status | String | 任务状态,可能的值包括:
|
output_file_id | String | 成功结果文件的ID,任务完成后生成。 |
error_file_id | String | 失败结果文件的ID,任务完成后且有失败请求时生成。 |
request_counts | Object | 包含total, completed, failed 数量的统计对象。 |
查询任务列表
可使用 batches.list() 方法查询 Batch 任务列表,通过分页机制逐步获取完整的任务列表。
OpenAI Python SDK
请求示例
import os
from openai import OpenAI
client = OpenAI(
# 若没有配置环境变量,可用阿里云百炼API Key将下行替换为:api_key="sk-xxx"。但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
# 新加坡和北京地域的API Key不同。
api_key=os.getenv("DASHSCOPE_API_KEY"),
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
base_url="https://dashscope.aliyuncs.com/compatible-mode/v1",
)
batches = client.batches.list(after="batch_xxx", limit=2,extra_query={'ds_name':'任务名称','input_file_ids':'file-batch-xxx,file-batch-xxx','status':'completed,expired','create_after':'20250304000000','create_before':'20250306123000'})
print(batches)OpenAI Node.js SDK
请求示例
/**
* 阿里云百炼 Batch API - 查询任务列表
*
* 若没有配置环境变量,可在代码中硬编码API Key:apiKey: 'sk-xxx'
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 安装依赖:npm install openai
*/
const OpenAI = require('openai');
// 北京地域配置(默认)
const BASE_URL = 'https://dashscope.aliyuncs.com/compatible-mode/v1';
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// const BASE_URL = 'https://dashscope-intl.aliyuncs.com/compatible-mode/v1';
// 注意:切换地域时,API Key也需要对应更换
const apiKey = process.env.DASHSCOPE_API_KEY;
if (!apiKey) {
console.error('错误: 请设置环境变量 DASHSCOPE_API_KEY');
console.error('或在代码中设置: const apiKey = "sk-xxx";');
process.exit(1);
}
const client = new OpenAI({
apiKey: apiKey,
baseURL: BASE_URL
});
const batches = await client.batches.list({
after: 'batch_xxx',
limit: 2,
extra_query: {
'ds_name': '任务名称',
'input_file_ids': 'file-batch-xxx,file-batch-xxx',
'status': 'completed,expired',
'create_after': '20250304000000',
'create_before': '20250306123000'
}
});
for (const batch of batches.data) {
console.log(batch.id, batch.status);
}Java(HTTP)
请求示例
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.Scanner;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
/**
* 阿里云百炼 Batch API - 查询任务列表
*
* 若没有配置环境变量,可在代码中硬编码API Key:API_KEY = "sk-xxx"
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 地域配置:
* - 北京地域:https://dashscope.aliyuncs.com/compatible-mode/v1
* - 新加坡地域:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
* 注意:切换地域时,API Key也需要对应更换
*/
public class BatchAPIListBatches {
// 北京地域配置(默认)
private static final String BASE_URL = "https://dashscope.aliyuncs.com/compatible-mode/v1";
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// private static final String BASE_URL = "https://dashscope-intl.aliyuncs.com/compatible-mode/v1";
// 注意:切换地域时,API Key也需要对应更换
private static String API_KEY;
public static void main(String[] args) throws Exception {
API_KEY = System.getenv("DASHSCOPE_API_KEY");
if (API_KEY == null || API_KEY.isEmpty()) {
System.err.println("错误: 请设置环境变量 DASHSCOPE_API_KEY");
System.err.println("或在代码中设置: API_KEY = \"sk-xxx\";");
System.exit(1);
}
String response = sendRequest("GET", "/batches?after=batch_xxx&limit=2&ds_name=Batch&input_file_ids=file-batch-xxx,file-batch-xxx&status=completed,failed&create_after=20250303000000&create_before=20250320000000", null);
// 解析 JSON 获取任务列表
System.out.println(response);
}
// === 工具方法 ===
private static String sendRequest(String method, String path, String jsonBody) throws Exception {
URL url = new URL(BASE_URL + path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod(method);
conn.setRequestProperty("Authorization", "Bearer " + API_KEY);
if (jsonBody != null) {
conn.setDoOutput(true);
conn.setRequestProperty("Content-Type", "application/json");
try (OutputStream os = conn.getOutputStream()) {
os.write(jsonBody.getBytes("UTF-8"));
}
}
return readResponse(conn);
}
private static String readResponse(HttpURLConnection conn) throws Exception {
int responseCode = conn.getResponseCode();
InputStream is = (responseCode < 400) ? conn.getInputStream() : conn.getErrorStream();
try (Scanner scanner = new Scanner(is, "UTF-8").useDelimiter("\\A")) {
return scanner.hasNext() ? scanner.next() : "";
}
}
private static String parseField(String json, String regex) {
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(json);
return matcher.find() ? matcher.group(1) : null;
}
}curl(HTTP)
请求示例
# ======= 重要提示 =======
# 新加坡和北京地域的API Key不同。
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1/batches?xxx同下方内容xxx
# === 执行时请删除该注释 ===
curl --request GET 'https://dashscope.aliyuncs.com/compatible-mode/v1/batches?after=batch_xxx&limit=2&ds_name=Batch&input_file_ids=file-batch-xxx,file-batch-xxx&status=completed,failed&create_after=20250303000000&create_before=20250320000000' \
-H "Authorization: Bearer $DASHSCOPE_API_KEY"将after=batch_id中的batch_id替换为实际值,limit参数设置为返回任务的数量,ds_name填写为任务名称片段,input_file_ids的值可填写多个文件ID,status填写Batch任务的多个状态,create_after和create_before的值填写为时间点。
输入参数
字段 | 类型 | 传参方式 | 必选 | 描述 |
after | String | Query | 否 | 用于分页的游标,值为上一页最后一个任务的ID。 |
limit | Integer | Query | 否 | 每页返回的任务数量,范围[1, 100],默认20。 |
ds_name | String | Query | 否 | 按任务名称进行模糊匹配。 |
input_file_ids | String | Query | 否 | 按文件 ID 筛选,多个 ID 用逗号分隔,最多20个。 |
status | String | Query | 否 | 按任务状态筛选,多个状态用逗号分隔。 |
create_after | String | Query | 否 | 筛选在此时间点之后创建的任务,格式: |
create_before | String | Query | 否 | 筛选在此时间点之前创建的任务,格式: |
返回示例
{
"object": "list",
"data": [
{
"id": "batch_xxx",
"object": "batch",
"endpoint": "/v1/chat/completions",
"errors": null,
"input_file_id": "file-batch-xxx",
"completion_window": "24h",
"status": "completed",
"output_file_id": "file-batch_output-xxx",
"error_file_id": null,
"created_at": 1722234109,
"in_progress_at": 1722234109,
"expires_at": null,
"finalizing_at": 1722234165,
"completed_at": 1722234165,
"failed_at": null,
"expired_at": null,
"cancelling_at": null,
"cancelled_at": null,
"request_counts": {
"total": 100,
"completed": 95,
"failed": 5
},
"metadata": {}
},
{ ... }
],
"first_id": "batch_xxx",
"last_id": "batch_xxx",
"has_more": true
}返回参数
字段 | 类型 | 描述 |
object | String | 类型,固定值list。 |
data | Array | Batch任务对象,参见创建Batch任务的返回参数。 |
first_id | String | 当前页第一个 Batch任务 ID。 |
last_id | String | 当前页最后一个Batch任务 ID。 |
has_more | Boolean | 是否有下一页。 |
取消Batch任务
取消一个正在进行或排队中的任务。成功调用后,任务状态将变为 cancelling,最终变为 cancelled。在任务被完全取消前,已完成的部分仍会计费。
OpenAI Python SDK
请求示例
import os
from openai import OpenAI
client = OpenAI(
# 若没有配置环境变量,可用阿里云百炼API Key将下行替换为:api_key="sk-xxx"。但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
# 新加坡和北京地域的API Key不同。
api_key=os.getenv("DASHSCOPE_API_KEY"),
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
base_url="https://dashscope.aliyuncs.com/compatible-mode/v1",
)
batch = client.batches.cancel("batch_id") # 将batch_id替换为Batch任务的id
print(batch)OpenAI Node.js SDK
请求示例
/**
* 阿里云百炼 Batch API - 取消任务
*
* 若没有配置环境变量,可在代码中硬编码API Key:apiKey: 'sk-xxx'
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 安装依赖:npm install openai
*/
const OpenAI = require('openai');
// 北京地域配置(默认)
const BASE_URL = 'https://dashscope.aliyuncs.com/compatible-mode/v1';
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// const BASE_URL = 'https://dashscope-intl.aliyuncs.com/compatible-mode/v1';
// 注意:切换地域时,API Key也需要对应更换
const apiKey = process.env.DASHSCOPE_API_KEY;
if (!apiKey) {
console.error('错误: 请设置环境变量 DASHSCOPE_API_KEY');
console.error('或在代码中设置: const apiKey = "sk-xxx";');
process.exit(1);
}
const client = new OpenAI({
apiKey: apiKey,
baseURL: BASE_URL
});
const batch = await client.batches.cancel('batch_id');
console.log(batch.status); // cancelledJava(HTTP)
请求示例
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.util.Scanner;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
/**
* 阿里云百炼 Batch API - 取消任务
*
* 若没有配置环境变量,可在代码中硬编码API Key:API_KEY = "sk-xxx"
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 地域配置:
* - 北京地域:https://dashscope.aliyuncs.com/compatible-mode/v1
* - 新加坡地域:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
* 注意:切换地域时,API Key也需要对应更换
*/
public class BatchAPICancelBatch {
// 北京地域配置(默认)
private static final String BASE_URL = "https://dashscope.aliyuncs.com/compatible-mode/v1";
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// private static final String BASE_URL = "https://dashscope-intl.aliyuncs.com/compatible-mode/v1";
// 注意:切换地域时,API Key也需要对应更换
private static String API_KEY;
public static void main(String[] args) throws Exception {
API_KEY = System.getenv("DASHSCOPE_API_KEY");
if (API_KEY == null || API_KEY.isEmpty()) {
System.err.println("错误: 请设置环境变量 DASHSCOPE_API_KEY");
System.err.println("或在代码中设置: API_KEY = \"sk-xxx\";");
System.exit(1);
}
String response = sendRequest("POST", "/batches/batch_id/cancel", null);
System.out.println(response);
}
// === 工具方法 ===
private static String sendRequest(String method, String path, String jsonBody) throws Exception {
URL url = new URL(BASE_URL + path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod(method);
conn.setRequestProperty("Authorization", "Bearer " + API_KEY);
if (jsonBody != null) {
conn.setDoOutput(true);
conn.setRequestProperty("Content-Type", "application/json");
try (OutputStream os = conn.getOutputStream()) {
os.write(jsonBody.getBytes("UTF-8"));
}
}
return readResponse(conn);
}
private static String readResponse(HttpURLConnection conn) throws Exception {
int responseCode = conn.getResponseCode();
InputStream is = (responseCode < 400) ? conn.getInputStream() : conn.getErrorStream();
try (Scanner scanner = new Scanner(is, "UTF-8").useDelimiter("\\A")) {
return scanner.hasNext() ? scanner.next() : "";
}
}
private static String parseField(String json, String regex) {
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(json);
return matcher.find() ? matcher.group(1) : null;
}
}curl(HTTP)
请求示例
# ======= 重要提示 =======
# 新加坡和北京地域的API Key不同。
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1/batches/batch_id/cancel
# === 执行时请删除该注释 ===
curl --request POST 'https://dashscope.aliyuncs.com/compatible-mode/v1/batches/batch_id/cancel' \
-H "Authorization: Bearer $DASHSCOPE_API_KEY"将batch_id替换为实际值。返回示例
取消任务成功后返回 Batch 任务的详细信息。以下是一个 cancelling 状态的返回示例:
{
"id": "batch_abc123",
"object": "batch",
"endpoint": "/v1/chat/completions",
"errors": null,
"input_file_id": "file-abc123",
"completion_window": "24h",
"status": "cancelling",
"output_file_id": null,
"error_file_id": null,
"created_at": 1711402400,
"in_progress_at": 1711402450,
"expires_at": 1711488800,
"finalizing_at": null,
"completed_at": null,
"failed_at": null,
"expired_at": null,
"cancelling_at": 1711403000,
"cancelled_at": null,
"request_counts": {
"total": 100,
"completed": 23,
"failed": 1
},
"metadata": null
}取消任务后,状态会先变为cancelling,等待正在执行的请求完成;最终会变为cancelled。已完成的请求结果仍会保存在输出文件中。
4. 下载Batch结果文件
任务结束后会生成结果文件(output_file_id)和可能的错误文件(error_file_id),两者均通过相同的文件下载接口获取。
仅支持下载以file-batch_output开头的file_id对应的文件。
OpenAI Python SDK
您可以通过content方法获取Batch任务结果文件内容,并通过write_to_file方法将其保存至本地。
请求示例
import os
from openai import OpenAI
client = OpenAI(
# 若没有配置环境变量,可用阿里云百炼API Key将下行替换为:api_key="sk-xxx"。但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
# 新加坡和北京地域的API Key不同。
api_key=os.getenv("DASHSCOPE_API_KEY"),
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
# 注意:切换地域时,API Key也需要对应更换
base_url="https://dashscope.aliyuncs.com/compatible-mode/v1",
)
content = client.files.content(file_id="file-batch_output-xxx")
# 打印结果文件内容
print(content.text)
# 保存结果文件至本地
content.write_to_file("result.jsonl")返回示例
{"id":"c308ef7f-xxx","custom_id":"1","response":{"status_code":200,"request_id":"c308ef7f-0824-9c46-96eb-73566f062426","body":{"created":1742303743,"usage":{"completion_tokens":35,"prompt_tokens":26,"total_tokens":61},"model":"qwen-plus","id":"chatcmpl-c308ef7f-0824-9c46-96eb-73566f062426","choices":[{"finish_reason":"stop","index":0,"message":{"content":"你好!当然可以。无论是需要信息查询、学习资料、解决问题的方法,还是其他任何帮助,我都在这里为你提供支持。请告诉我你需要什么方面的帮助?"}}],"object":"chat.completion"}},"error":null}
{"id":"73291560-xxx","custom_id":"2","response":{"status_code":200,"request_id":"73291560-7616-97bf-87f2-7d747bbe84fd","body":{"created":1742303743,"usage":{"completion_tokens":7,"prompt_tokens":26,"total_tokens":33},"model":"qwen-plus","id":"chatcmpl-73291560-7616-97bf-87f2-7d747bbe84fd","choices":[{"finish_reason":"stop","index":0,"message":{"content":"2+2 equals 4."}}],"object":"chat.completion"}},"error":null}OpenAI Node.js SDK
您可以通过content方法获取Batch任务结果文件内容。
请求示例
/**
* 阿里云百炼 Batch API - 下载结果文件
*
* 若没有配置环境变量,可在代码中硬编码API Key:apiKey: 'sk-xxx'
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 安装依赖:npm install openai
*/
const OpenAI = require('openai');
const fs = require('fs');
// 北京地域配置(默认)
const BASE_URL = 'https://dashscope.aliyuncs.com/compatible-mode/v1';
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// const BASE_URL = 'https://dashscope-intl.aliyuncs.com/compatible-mode/v1';
// 注意:切换地域时,API Key也需要对应更换
const apiKey = process.env.DASHSCOPE_API_KEY;
if (!apiKey) {
console.error('错误: 请设置环境变量 DASHSCOPE_API_KEY');
console.error('或在代码中设置: const apiKey = "sk-xxx";');
process.exit(1);
}
const client = new OpenAI({
apiKey: apiKey,
baseURL: BASE_URL
});
// 下载结果文件
const content = await client.files.content('file-batch_output-xxx');
const text = await content.text();
console.log(text);
// 保存到本地文件
fs.writeFileSync('result.jsonl', text);
console.log('结果已保存到 result.jsonl');Java(HTTP)
您可以通过GET请求到/files/{file_id}/content端点获取文件内容。
请求示例
import java.io.*;
import java.net.HttpURLConnection;
import java.net.URL;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.Scanner;
import java.util.regex.Pattern;
import java.util.regex.Matcher;
/**
* 阿里云百炼 Batch API - 下载结果文件
*
* 若没有配置环境变量,可在代码中硬编码API Key:API_KEY = "sk-xxx"
* 但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
* 新加坡和北京地域的API Key不同。
*
* 地域配置:
* - 北京地域:https://dashscope.aliyuncs.com/compatible-mode/v1
* - 新加坡地域:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
* 注意:切换地域时,API Key也需要对应更换
*/
public class BatchAPIDownloadFile {
// 北京地域配置(默认)
private static final String BASE_URL = "https://dashscope.aliyuncs.com/compatible-mode/v1";
// 如果使用新加坡地域,请将上面的 BASE_URL 替换为:
// private static final String BASE_URL = "https://dashscope-intl.aliyuncs.com/compatible-mode/v1";
// 注意:切换地域时,API Key也需要对应更换
private static String API_KEY;
public static void main(String[] args) throws Exception {
API_KEY = System.getenv("DASHSCOPE_API_KEY");
if (API_KEY == null || API_KEY.isEmpty()) {
System.err.println("错误: 请设置环境变量 DASHSCOPE_API_KEY");
System.err.println("或在代码中设置: API_KEY = \"sk-xxx\";");
System.exit(1);
}
// 下载结果文件
String content = sendRequest("GET", "/files/file-batch_output-xxx/content", null);
System.out.println(content);
// 保存到本地文件
Files.write(Paths.get("result.jsonl"), content.getBytes());
System.out.println("结果已保存到 result.jsonl");
}
// === 工具方法 ===
private static String sendRequest(String method, String path, String jsonBody) throws Exception {
URL url = new URL(BASE_URL + path);
HttpURLConnection conn = (HttpURLConnection) url.openConnection();
conn.setRequestMethod(method);
conn.setRequestProperty("Authorization", "Bearer " + API_KEY);
if (jsonBody != null) {
conn.setDoOutput(true);
conn.setRequestProperty("Content-Type", "application/json");
try (OutputStream os = conn.getOutputStream()) {
os.write(jsonBody.getBytes("UTF-8"));
}
}
return readResponse(conn);
}
private static String readResponse(HttpURLConnection conn) throws Exception {
int responseCode = conn.getResponseCode();
InputStream is = (responseCode < 400) ? conn.getInputStream() : conn.getErrorStream();
try (Scanner scanner = new Scanner(is, "UTF-8").useDelimiter("\\A")) {
return scanner.hasNext() ? scanner.next() : "";
}
}
private static String parseField(String json, String regex) {
Pattern pattern = Pattern.compile(regex);
Matcher matcher = pattern.matcher(json);
return matcher.find() ? matcher.group(1) : null;
}
}curl(HTTP)
您可以通过GET方法,在URL中指定file_id来下载Batch任务结果文件。
请求示例
# ======= 重要提示 =======
# 新加坡和北京地域的API Key不同。
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1/files/file-batch_output-xxx/content
# === 执行时请删除该注释 ===
curl -X GET https://dashscope.aliyuncs.com/compatible-mode/v1/files/file-batch_output-xxx/content \
-H "Authorization: Bearer $DASHSCOPE_API_KEY" > result.jsonl返回示例
单条响应结果:
{
"id": "c308ef7f-xxx",
"custom_id": "1",
"response": {
"status_code": 200,
"request_id": "c308ef7f-0824-9c46-96eb-73566f062426",
"body": {
"created": 1742303743,
"usage": {
"completion_tokens": 35,
"prompt_tokens": 26,
"total_tokens": 61
},
"model": "qwen-plus",
"id": "chatcmpl-c308ef7f-0824-9c46-96eb-73566f062426",
"choices": [
{
"finish_reason": "stop",
"index": 0,
"message": {
"content": "你好!当然可以。无论是需要信息查询、学习资料、解决问题的方法,还是其他任何帮助,我都在这里为你提供支持。请告诉我你需要什么方面的帮助?"
}
}
],
"object": "chat.completion"
}
},
"error": null
}返回参数
字段 | 类型 | 描述 |
id | String | 请求 ID。 |
custom_id | String | 用户自定义的 ID。 |
response | Object | 请求结果。 |
status_code | Integer | 状态码。200表示请求成功。 |
request_id | String | 服务端为这次请求生成的唯一ID。 |
completion_tokens | Integer | 模型生成的回复内容(completion)所消耗的Token数量。 |
prompt_tokens | Integer | 发送给模型的输入内容( |
reasoning_tokens | Integer | 深度思考模型的思考过程token数。 |
total_tokens | Integer | 本次调用总共消耗的Token数量。 |
model | String | 本次调用所使用的模型名称。 |
reasoning_content | String | 深度思考模型的思考过程。 |
error | Object | 错误信息对象。如果API调用成功,该值为 |
error.code | String | 错误行信息和错误原因,可参考错误码进行排查。 |
error.message | String | 错误信息。 |
进阶功能
使用 OSS 文件创建 Batch 任务
对于大型文件,推荐将其存储在阿里云 OSS 中,并通过 input_file_id 直接引用,以避免本地上传的限制。
方式一:使用文件 URL
将具有公共读权限或预签名授权的 OSS 文件 URL 直接作为 input_file_id:
batch_job = client.batches.create(
input_file_id="https://your-bucket.oss-cn-beijing.aliyuncs.com/file.jsonl?Expires=...",
endpoint="/v1/chat/completions",
completion_window="24h"
)获取文件URL
OSS 控制台
进入Bucket列表页面,找到目标Bucket并单击名称;
在文件列表中定位目标文件,单击右侧详情按钮;
您可在文件列表中新建子文件夹如Batch/20260101并上传文件,示例test.jsonl。
在弹出面板中,单击复制文件URL。
SDK:生成 OSS 文件 URL,参考使用预签名URL下载文件。
方式二:使用资源标识符(推荐)
完成 OSS 授权
参阅从OSS导入文件配置说明的授权和添加标签步骤。
参数配置
使用
oss:{region}:{bucket}/{file_path}格式的 OSS 资源标识符:batch_job = client.batches.create( input_file_id="oss:cn-beijing:your-bucket/path/to/file.jsonl", endpoint="/v1/chat/completions", completion_window="24h" )
建议:
使用与阿里云百炼服务同地域 Bucket(
cn-beijing)可利用阿里云内网传输,降低网络延迟、提升稳定性并避免跨地域流量费用。方式二更安全,依赖 RAM 授权而非公开 URL。
配置任务完成通知
对于长时间运行的任务,轮询会消耗不必要的资源。建议使用异步通知机制,系统会在任务完成后主动通知。
Callback 回调:在创建任务时指定一个公网可访问的 URL
EventBridge 消息队列:与阿里云生态深度集成,无需公网 IP
方式一:Callback 回调
在创建任务时通过 metadata 指定一个公网可访问的 URL。任务完成后,系统会向指定 URL 发送包含任务状态的 POST 请求:
OpenAI Python SDK
import os
from openai import OpenAI
client = OpenAI(
# 若没有配置环境变量,可用阿里云百炼API Key将下行替换为:api_key="sk-xxx"。但不建议在生产环境中直接将API Key硬编码到代码中,以减少API Key泄露风险。
# 新加坡和北京地域的API Key不同。
api_key=os.getenv("DASHSCOPE_API_KEY"),
# 以下是北京地域base_url,如果使用新加坡地域的模型,需要将base_url替换为:https://dashscope-intl.aliyuncs.com/compatible-mode/v1
# 注意:切换地域时,API Key也需要对应更换
base_url="https://dashscope.aliyuncs.com/compatible-mode/v1",
)
batch = client.batches.create(
input_file_id="file-batch-xxx", # 上传文件返回的 id
endpoint="/v1/chat/completions", # Embedding文本向量模型填写"/v1/embeddings",测试模型batch-test-model填写/v1/chat/ds-test,其他模型填写/v1/chat/completions
completion_window="24h",
metadata={
"ds_batch_finish_callback": "https://xxx/xxx"
}
)
print(batch)curl(HTTP)
请求示例
curl -X POST --location "https://dashscope.aliyuncs.com/compatible-mode/v1/batches" \
-H "Authorization: Bearer $DASHSCOPE_API_KEY" \
-H "Content-Type: application/json" \
-d '{
"input_file_id": "file-batch-xxxxx",
"endpoint": "/v1/chat/completions",
"completion_window": "24h",
"metadata": {
"ds_batch_finish_callback": "https://xxx/xxx"
}
}'方式二:EventBridge 消息队列
此方式无需公网 IP,适用于需要与阿里云其他服务(如函数计算、RocketMQ)集成的复杂场景。
当 Batch 任务完成时,系统会向阿里云事件总线 EventBridge 发送一个事件。您可以配置 EventBridge 规则来监听此事件,并将其路由到指定目标。
事件源 (Source):
acs.dashscope事件类型 (Type):
dashscope:System:BatchTaskFinish
相关文档:路由到消息队列RocketMQ版。
应用于生产环境
文件管理
定期调用 OpenAI-File删除文件接口删除不需要的文件,避免达到文件存储上限(10000个文件或100GB)
对于大型文件,推荐将其存储在阿里云 OSS 中
任务监控
优先使用 Callback 或 EventBridge 异步通知
轮询间隔 > 1分钟,使用指数退避策略
错误处理
实现完整的异常处理机制,包括网络错误、API错误等
下载并分析
error_file_id的错误详情对于常见错误码,参考错误信息进行解决
成本优化
将时效性要求不高的任务迁移到 Batch API
合并小任务到一个批次
合理设置
completion_window提供更多调度灵活性
实用工具
CSV 转 JSONL
如果原始数据存储在 CSV 文件中(第一列为 ID,第二列为内容),可使用以下脚本快速生成 Batch 任务所需的 JSONL 文件。
如需调整文件路径或其他参数,请根据实际情况修改代码。
import csv
import json
def messages_builder_example(content):
messages = [{"role": "system", "content": "You are a helpful assistant."}, {"role": "user", "content": content}]
return messages
with open("input_demo.csv", "r") as fin:
with open("input_demo.jsonl", 'w', encoding='utf-8') as fout:
csvreader = csv.reader(fin)
for row in csvreader:
body = {"model": "qwen-turbo", "messages": messages_builder_example(row[1])}
# 选择Embedding文本向量模型进行调用时,url的值需填写"/v1/embeddings",其他模型填写/v1/chat/completions
request = {"custom_id": row[0], "method": "POST", "url": "/v1/chat/completions", "body": body}
fout.write(json.dumps(request, separators=(',', ':'), ensure_ascii=False) + "\n")JSONL 结果转 CSV
使用以下脚本可将 result.jsonl 文件解析为易于在 Excel 中分析的 result.csv 文件。
如需调整文件路径或其他参数,请根据实际情况修改代码。
import json
import csv
columns = ["custom_id",
"model",
"request_id",
"status_code",
"error_code",
"error_message",
"created",
"content",
"usage"]
def dict_get_string(dict_obj, path):
obj = dict_obj
try:
for element in path:
obj = obj[element]
return obj
except:
return None
with open("result.jsonl", "r") as fin:
with open("result.csv", 'w', encoding='utf-8') as fout:
rows = [columns]
for line in fin:
request_result = json.loads(line)
row = [dict_get_string(request_result, ["custom_id"]),
dict_get_string(request_result, ["response", "body", "model"]),
dict_get_string(request_result, ["response", "request_id"]),
dict_get_string(request_result, ["response", "status_code"]),
dict_get_string(request_result, ["error", "error_code"]),
dict_get_string(request_result, ["error", "error_message"]),
dict_get_string(request_result, ["response", "body", "created"]),
dict_get_string(request_result, ["response", "body", "choices", 0, "message", "content"]),
dict_get_string(request_result, ["response", "body", "usage"])]
rows.append(row)
writer = csv.writer(fout)
writer.writerows(rows)Excel 乱码解决
可使用文本编辑器(如Sublime)将 CSV 文件的编码转换为GBK,然后再用Excel打开。
或在 Excel 中新建一个 Excel 文件,并在导入数据时指定正确的编码格式 UTF-8。
接口限流
接口 | 限流(主账号级别) |
创建任务 | 1000 次/分钟,最大并发 1000 个 |
查询任务 | 1000 次/分钟 |
查询任务列表 | 100 次/分钟 |
取消任务 | 1000 次/分钟 |
计费说明
计费单价:所有成功请求的输入和输出Token,单价均为对应模型实时推理价格的50%,具体请参见模型列表。
计费范围:
仅对任务中成功执行的请求进行计费。
文件解析失败、任务执行失败、或行级错误请求均不产生费用。
对于被取消的任务,在取消操作前已成功完成的请求仍会正常计费。
错误码
如果调用失败并返回报错信息,请参见错误信息进行解决。
常见问题
Batch调用如何计费?需要单独购买吗?
答:Batch是一种调用方式,采用后付费模式,根据任务中成功请求的Token使用量计费,无需额外购买套餐。
提交的Batch任务是按顺序执行的吗?
答:不是。后台采用动态调度机制,系统会根据当前整体的计算资源负载来安排任务执行,不保证严格遵循提交顺序。在资源紧张时,任务启动和执行可能会有延迟。
提交的Batch任务需要多长时间完成?
答:执行时间取决于系统资源分配情况和您的任务规模。若任务在您设定的 completion_window内未能完成,其状态将变为expired,此时未处理的请求将不会再执行,也不会产生费用。
场景建议:对模型推理时效性有严格要求的场景,建议使用实时调用;对于处理大规模数据且对时效性有一定容忍度的场景,推荐使用Batch调用。