HTTP数据

简介

service_http_server input插件可以接收来自unix socket、http/https、tcp的请求,并支持sls协议、otlp等多种协议。

配置参数

参数类型是否必选说明

Type

String

插件类型,固定为service_http_server

Format

String

数据格式。

支持格式:slsprometheusinfluxdbotlp_logv1statsd

Address

String

监听地址。

ReadTimeoutSec

String

读取超时时间。

默认取值为:10s

ShutdownTimeoutSec

String

关闭超时时间。

默认取值为:5s

MaxBodySize

String

最大传输 body 大小。

默认取值为:64k

UnlinkUnixSock

String

启动前如果监听地址为unix socket,是否进行强制释放。

默认取值为:true

样例

接收 OTLP 日志

  • 采集配置

enable: true
inputs:
  - Type: service_http_server
    Format: "otlp_logv1"
    Address: "http://127.0.0.1:12345"
flushers:
  - Type: flusher_stdout
    OnlyStdout: true  
  • 输入

使用 opentelemetry-java-sdk构造数据,基于ExampleConfiguration.javaOtlpExporterExample.java进行如下代码改造。

ExampleConfiguration 进行 OTLP SDK 初始化。

  static OpenTelemetrySdk initHTTPOpenTelemetry() {
    // Include required service.name resource attribute on all spans and metrics
    Resource resource =
        Resource.getDefault()
            .merge(Resource.builder().put(SERVICE_NAME, "OtlpExporterExample").build());

    OpenTelemetrySdk openTelemetrySdk =
        OpenTelemetrySdk.builder()
            .setLogEmitterProvider(
                SdkLogEmitterProvider.builder()
                    .setResource(resource)
                    .addLogProcessor(SimpleLogProcessor
                        .create(OtlpHttpLogExporter
                                .builder()
                                .setEndpoint("http://127.0.0.1:12345/v1/logs")
                                .build()))
                    .build())
            .buildAndRegisterGlobal();

    Runtime.getRuntime()
        .addShutdownHook(new Thread(openTelemetrySdk.getSdkLogEmitterProvider()::shutdown));

    return openTelemetrySdk;
  }

OtlpExporterExample 构造数据。

  OpenTelemetrySdk openTelemetry = ExampleConfiguration.initHTTPOpenTelemetry();

  LogEmitter logger = openTelemetry.getSdkLogEmitterProvider().get("io.opentelemetry.example");
  logger
    .logRecordBuilder()
    .setBody("log body1")
    .setAllAttributes(
      Attributes.builder()
                  .put("k1", "v1")
                  .put("k2", "v2").build())
    .setSeverity(Severity.INFO)
    .setSeverityText("INFO")
    .setEpoch(Instant.now())
    .setContext(Context.current())
    .emit();
  • 输出

{
    "time_unix_nano": "1663913736115000000",
    "severity_number": "9",
    "severity_text": "INFO",
    "content": "log body1",
    "attributes": "{\"k1\":\"v1\",\"k2\":\"v2\"}",
    "resources": "{\"service.name\":\"OtlpExporterExample\",\"telemetry.sdk.language\":\"java\",\"telemetry.sdk.name\":\"opentelemetry\",\"telemetry.sdk.version\":\"1.18.0\"}",
    "__time__": "1663913736"
}

Last updated