Skip to content
This repository has been archived by the owner on Feb 27, 2024. It is now read-only.

Latest commit

 

History

History
19 lines (10 loc) · 1.14 KB

proto-design-goals.md

File metadata and controls

19 lines (10 loc) · 1.14 KB

Design Goals for OpenTelemetry Wire Protocol

We want to design a telemetry data exchange protocol that has the following characteristics:

  • Be suitable for use between all of the following node types: instrumented applications, telemetry backends, local agents, stand-alone collectors/forwarders.

  • Have high reliability of data delivery and clear visibility when the data cannot be delivered.

  • Have low CPU usage for serialization and deserialization.

  • Impose minimal pressure on memory manager, including pass-through scenarios, where deserialized data is short-lived and must be serialized as-is shortly after and where such short-lived data is created and discarded at high frequency (think telemetry data forwarders).

  • Support ability to efficiently modify deserialized data and serialize again to pass further. This is related but slightly different from the previous requirement.

  • Ensure high throughput (within the available bandwidth) in high latency networks (e.g. scenarios where telemetry source and the backend are separated by high latency network).

  • Allow backpressure signalling.

  • Be load-balancer friendly (do not hinder re-balancing).