Demo Architecture

OpenTelemetry Demo is composed of microservices written in different programming languages that talk to each other over gRPC and HTTP; and a load generator which uses Locust to fake user traffic.

Service Diagram
HTTP
HTTP
HTTP
HTTP
TCP
gRPC
gRPC
gRPC
HTTP
gRPC
gRPC
TCP
gRPC
gRPC
gRPC
gRPC
gRPC
gRPC
gRPC
gRPC
HTTP
TCP
gRPC
gRPC
gRPC
gRPC
Accounting Service
Internet
Frontend Proxy
(Envoy)
Frontend
Feature Flag Service
Load Generator
queue
(Kafka)
Checkout Service
Cart Service
Cache
(redis)
Product Catalog Service
Currency Service
Email Service
Payment Service
Shipping Service
Ad Service
Recommendation Service
Quote Service
Fraud Detection Service
Feature Flag Store
(PostgreSQL DB)
Service Legend
.NET
C++
Erlang/Elixir
Go
Java
JavaScript
Kotlin
PHP
Python
Ruby
Rust
TypeScript

Follow these links for the current state of metric and trace instrumentation of the demo applications.

The collector is configured in otelcol-config.yml, alternative exporters can be configured here.

Telemetry Data Flow
Open Telemetry Demo
OTel Collector
Prometheus
Jaeger
Grafana
OTLP
gRPC
OTLP
HTTP POST
http://localhost:9464/metrics
gRPC
http://localhost:9090/graph
http://localhost:9090/api
http://localhost:16686/api
http://localhost:16686/search
http://localhost:3000/dashboard
Microservice
OTLP Receiver
listening on
grpc://localhost:4317/
OTLP Receiver
listening on
http://localhost:4318/
https://localhost:4318/
Processors
Prometheus Exporter
listening on
http://localhost:9464/
Jaeger Exporter
Prometheus Scraper
polling every 5 seconds
Jaeger Collector
listening on
grpc://jaeger:4317/
Prometheus TSDB
Prometheus HTTP
listening on
http://localhost:9090
Browser
Prometheus UI
Jaeger DB
Jaeger HTTP
listening on
http://localhost:16686
Grafana Server
Grafana HTTP
listening on
http://localhost:3000
Browser
Jaeger UI
Browser
Grafana UI

Find the Protocol Buffer Definitions in the /pb/ directory.