tencent cloud

CreateRealtimeLogDeliveryTask
Last updated: 2025-10-30 22:02:25
CreateRealtimeLogDeliveryTask
Last updated: 2025-10-30 22:02:25

1. API Description

Domain name for API request: teo.intl.tencentcloudapi.com.

This API is used to create a real-time log delivery task.
The following restrictions apply:

  • When the log type (LogType) is site acceleration log (L7 access log) (domain), L4 proxy log (application), or Edge Function execution log (function), the same entity (L7 domain, L4 proxy instance, or Edge Function instance) can be added to only one of the following TaskType combinations within the same LogType-Area pair:
    • One task delivering to Tencent Cloud CLS plus one task delivering to a custom HTTP(S) endpoint;
    • One task delivering to Tencent Cloud CLS plus one task delivering to an AWS S3-compatible bucket.
  • When the log type (LogType) is rate-limiting & CC attack protection log (web-rateLiming), managed rule log (web-attack), custom rule log (web-rule), or bot management log (web-bot), the same entity can be added to only one real-time log delivery task within the same LogType-Area pair.

Before creating a task, we recommend that you first call DescribeRealtimeLogDeliveryTasks to list existing tasks for the entity and verify whether it has already been added to another task.

A maximum of 20 requests can be initiated per second for this API.

We recommend you to use API Explorer
Try it
API Explorer provides a range of capabilities, including online call, signature authentication, SDK code generation, and API quick search. It enables you to view the request, response, and auto-generated examples.

2. Input Parameters

The following request parameter list only provides API request parameters and some common parameters. For the complete common parameter list, see Common Request Parameters.

Parameter Name Required Type Description
Action Yes String Common Params. The value used for this API: CreateRealtimeLogDeliveryTask.
Version Yes String Common Params. The value used for this API: 2022-09-01.
Region No String Common Params. This parameter is not required.
ZoneId Yes String Zone ID.
TaskName Yes String Name of a real-time log delivery task, which can contain up to 200 characters, including digits, English letters, hyphens (-) and underscores (_).
TaskType Yes String Type of a real-time log delivery task. Valid values:
  • cls: push to Tencent Cloud CLS;
  • custom_endpoint: push to a custom HTTP(S) endpoint;
  • s3: push to an AWS S3-compatible bucket.
  • EntityList.N Yes Array of String List of entities associated with the real-time log delivery task. Valid value examples:
  • L7 domain name: domain.example.com
  • L4 proxy instance: sid-2s69eb5wcms7
  • Edge Function instance: test-zone-2mxigizoh9l9-1257626257

  • Reference for values
    DescribeL4Proxy
    DescribeAccelerationDomains
    DescribeFunctions
    LogType Yes String Dataset type. Valid values:
  • domain: site acceleration logs;
  • application: L4 proxy logs;
  • function: Edge Function execution log;
  • web-rateLiming: rate limiting and CC attack protection logs;
  • web-attack: managed rule logs;
  • web-rule: custom rule logs;
  • web-bot: Bot management logs.
  • Area Yes String Data area. Valid values:
  • mainland: within the Chinese mainland;
  • overseas: global (excluding the Chinese mainland).
  • Fields.N Yes Array of String Pre-defined log fields to be delivered. Refer to:
  • Site acceleration log (L7 access log)
  • L4 proxy log
  • Edge Function execution log
  • CustomFields.N No Array of CustomField The list of custom fields for log delivery, which supports extracting specified content from HTTP request headers, response headers, cookies, and request bodies. Custom field names must be unique. The number of custom fields cannot exceed a maximum of 200. A single real-time log delivery task can configure up to 5 custom fields of the request body type. Currently, only site acceleration logs (LogType=domain) support custom fields.
    DeliveryConditions.N No Array of DeliveryCondition Filter criteria of log delivery. If this parameter is not specified, all logs will be delivered.
    Sample No Integer Sampling ratio in permille. Value range: 1-1000. For example, 605 indicates a sampling ratio of 60.5%. If this parameter is not specified, the sampling ratio is 100%.
    LogFormat No LogFormat Output format for log delivery. If this field is not specified, the default format is used, which works as follows:
  • When TaskType is custom_endpoint, the default format is an array of JSON objects, with each JSON object representing a log entry;
  • When TaskType is s3, the default format is JSON Lines;
  • Specifically, when TaskType is cls, the only allowed value for LogFormat.FormatType is json, and other parameters in LogFormat will be ignored. It is recommended not to input LogFormat.
    CLS No CLSTopic Configuration information of CLS. This parameter is required when TaskType is cls.
    CustomEndpoint No CustomEndpoint Configuration information of the custom HTTP endpoint. This parameter is required when TaskType is custom_endpoint.
    S3 No S3 Configuration information of the AWS S3-compatible bucket. This parameter is required when TaskType is s3.

    3. Output Parameters

    Parameter Name Type Description
    TaskId String ID of the successfully created task.
    RequestId String The unique request ID, generated by the server, will be returned for every request (if the request fails to reach the server for other reasons, the request will not obtain a RequestId). RequestId is required for locating a problem.

    4. Example

    Example1 Creating a Log Delivery Task with the Destination Set to Tencent Cloud CLS

    This example shows you how to create a log delivery task with the destination set to Tencent Cloud CLS. The delivery data range includes the site acceleration log generated by domain.example.com in the Chinese mainland. The data includes the RequestID, ClientIP, and RequestTime fields, and field values extracted from the Accept-Language request header. The configuration sampling ratio is 60.5%.

    Input Example

    POST / HTTP/1.1
    Host: teo.intl.tencentcloudapi.com
    Content-Type: application/json
    X-TC-Action: CreateRealtimeLogDeliveryTask
    <Common request parameters>
    
    {
        "ZoneId": "zone-xxxxx",
        "TaskName": "test_log_task",
        "TaskType": "cls",
        "EntityList": [
            "domain.example.com"
        ],
        "LogType": "domain",
        "Area": "mainland",
        "Fields": [
            "RequestID",
            "ClientIP",
            "RequestTime"
        ],
        "CustomFields": [
            {
                "Name": "ReqHeader",
                "Value": "Accept-Language",
                "Enabled": true
            }
        ],
        "Sample": 605,
        "CLS": {
            "LogSetId": "1a6efff1-0e40-4d37-a4ed-02c92513406b",
            "TopicId": "0b3a07c0-5cf6-4017-8a75-cd4459aea588",
            "LogSetRegion": "ap-guangzhou"
        }
    }

    Output Example

    {
        "Response": {
            "TaskId": "26580056-1187-43ed-b2c7-ecdb5bae0b46",
            "RequestId": "5e0a2b4e-df6d-4d2a-ac39-1706cbf8a703"
        }
    }

    Example2 Creating a Log Delivery Task with the Destination Set to a Custom HTTP Service

    This example shows you how to create a log delivery task with the destination set to a custom HTTP service. The delivery data range includes the site acceleration log generated by domain.example.com in the Chinese mainland and with the final security handling method being interception or challenge. The data includes the RequestID, ClientIP, and RequestTime fields. Log sampling is disabled, log delivery compression is enabled, and the custom request header Vendor with a constant value of EdgeOne is carries during log delivery.

    Input Example

    POST / HTTP/1.1
    Host: teo.intl.tencentcloudapi.com
    Content-Type: application/json
    X-TC-Action: CreateRealtimeLogDeliveryTask
    <Common request parameters>
    
    {
        "ZoneId": "zone-xxxxx",
        "TaskName": "test_log_task",
        "TaskType": "custom_endpoint",
        "EntityList": [
            "domain.example.com"
        ],
        "LogType": "domain",
        "Area": "mainland",
        "Fields": [
            "RequestID",
            "ClientIP",
            "RequestTime"
        ],
        "Sample": 1000,
        "DeliveryConditions": [
            {
                "Conditions": [
                    {
                        "Key": "SecurityAction",
                        "Operator": "equal",
                        "Value": [
                            "Deny",
                            "JSChallenge",
                            "ManagedChallenge"
                        ]
                    }
                ]
            }
        ],
        "CustomEndpoint": {
            "Url": "http://custom_endpoint/access_log/post",
            "CompressType": "gzip",
            "Headers": [
                {
                    "Name": "Vendor",
                    "Value": "EdgeOne"
                }
            ]
        }
    }

    Output Example

    {
        "Response": {
            "TaskId": "26580056-1187-43ed-b2c7-ecdb5bae0b46",
            "RequestId": "5e0a2b4e-df6d-4d2a-ac39-1706cbf8a703"
        }
    }

    5. Developer Resources

    SDK

    TencentCloud API 3.0 integrates SDKs that support various programming languages to make it easier for you to call APIs.

    Command Line Interface

    6. Error Code

    The following only lists the error codes related to the API business logic. For other error codes, see Common Error Codes.

    Error Code Description
    FailedOperation Operation failed.
    FailedOperation.CreateClsLogSetFailed Failed to create the log set. Check whether the log set name already exists.
    FailedOperation.CreateClsLogTopicTaskFailed Failed to create the log topic task. Check whether the log topic name or task name already exists.
    FailedOperation.CreateLogTopicTaskAuthFailure Authentication failed while creating a custom push task. Check whether the push address is correct.
    FailedOperation.RealtimeLogAuthFailure The real-time log authentication failed.
    FailedOperation.RealtimeLogNotFound The real-time log push task does not exist.
    InvalidParameter Parameter error.
    InvalidParameter.InvalidLogFormatFieldDelimiter The field separator in the log output format is incorrect.
    InvalidParameter.InvalidLogFormatFormatType The log output format type is incorrect.
    InvalidParameter.InvalidLogFormatRecordDelimiter The log record separator in the log output format is incorrect.
    InvalidParameter.RealtimeLogEntityAlreadyCreated The push instance has been created.
    InvalidParameter.RealtimeLogInvalidDeliveryArea The log push region is invalid.
    InvalidParameter.RealtimeLogInvalidLogType The log push type is invalid.
    InvalidParameter.RealtimeLogInvalidTaskType The real-time log delivery type is invalid.
    InvalidParameter.RealtimeLogNumsExceedLimit The real-time log push task data exceeded the limit.
    InvalidParameterValue Invalid parameter value.
    LimitExceeded The quota limit has been reached.
    LimitExceeded.CustomLogFieldRegexLimitExceeded The number of regular expression type fields in real-time log custom fields exceeds the limit.
    OperationDenied Operation denied.
    ResourceNotFound The resource doesn’t exist.
    ResourceUnavailable The resource is unavailable.
    UnauthorizedOperation.NoPermission The sub-account is not authorized for the operation. Please get permissions first.
    Was this page helpful?
    You can also Contact Sales or Submit a Ticket for help.
    Yes
    No

    Feedback