1 Star 0 Fork 688

徐建明 / skywalking

forked from SkyWalking / skywalking 
加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
克隆/下载
README.md 3.62 KB
一键复制 编辑 原始数据 按行查看 历史
Wing 提交于 2021-11-02 01:49 . Refine protocols doc (#8049)

Probe Protocols

Probe protocols describe and define how agents send collected metrics, logs, traces, and events, as well as set out the format of each entity.

Tracing

There are two types of protocols that help language agents work in distributed tracing.

  • Cross Process Propagation Headers Protocol and Cross Process Correlation Headers Protocol come in in-wire data format. Agent/SDK usually uses HTTP/MQ/HTTP2 headers to carry the data with the RPC request. The remote agent will receive this in the request handler, and bind the context with this specific request.

Cross Process Propagation Headers Protocol v3 has been the new protocol for in-wire context propagation since the version 8.0.0 release.

Cross Process Correlation Headers Protocol v1 is a new in-wire context propagation protocol which is additional and optional. Please read SkyWalking language agents documentation to see whether it is supported.

  • Trace Data Protocol is an out-of-wire data format. Agent/SDK uses this to send traces to SkyWalking OAP server.

SkyWalking Trace Data Protocol v3 defines the communication method and format between the agent and backend.

Logging

  • Log Data Protocol is an out-of-wire data format. Agent/SDK and collector use this to send logs into SkyWalking OAP server. SkyWalking Log Data Protocol defines the communication method and format between the agent and backend.

Metrics

SkyWalking has a native metrics format, and supports widely used metric formats, such as Prometheus, OpenCensus, and Zabbix.

The native metrics format definition could be found here. Typically, the agent meter plugin (e.g. Java Meter Plugin) and Satellite Prometheus fetcher would convert metrics into native format and forward them to SkyWalking OAP server.

To learn more about receiving 3rd party formats metrics, see Meter receiver and OpenTelemetry receiver.

Browser probe protocol

The browser probe, such as skywalking-client-js, could use this protocol to send data to the backend. This service is provided by gRPC.

SkyWalking Browser Protocol defines the communication method and format between skywalking-client-js and backend.

Events Report Protocol

The protocol is used to report events to the backend. The doc introduces the definition of an event, and the protocol repository defines gRPC services and message formats of events.

JSON format events can be reported via HTTP API. The endpoint is http://<oap-address>:12800/v3/events. Example of a JSON event record:

[
    {
        "uuid": "f498b3c0-8bca-438d-a5b0-3701826ae21c",
        "source": {
            "service": "SERVICE-A",
            "instance": "INSTANCE-1"
        },
        "name": "Reboot",
        "type": "Normal",
        "message": "App reboot.",
        "parameters": {},
        "startTime": 1628044330000,
        "endTime": 1628044331000
    }
]
Java
1
https://gitee.com/xujianming2018/sky-walking.git
git@gitee.com:xujianming2018/sky-walking.git
xujianming2018
sky-walking
skywalking
master

搜索帮助