Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/nextrevision/jaeger-otel-clickhouse-backend
A Jaeger gRPC compatible backend for viewing traces exported by the OpenTelemetry clickhouseexporter plugin
https://github.com/nextrevision/jaeger-otel-clickhouse-backend
clickhouse jaeger jaegertracing observability opentelemetry
Last synced: 3 months ago
JSON representation
A Jaeger gRPC compatible backend for viewing traces exported by the OpenTelemetry clickhouseexporter plugin
- Host: GitHub
- URL: https://github.com/nextrevision/jaeger-otel-clickhouse-backend
- Owner: nextrevision
- License: gpl-3.0
- Created: 2024-04-07T05:25:15.000Z (9 months ago)
- Default Branch: main
- Last Pushed: 2024-07-08T08:28:34.000Z (6 months ago)
- Last Synced: 2024-09-27T07:01:12.454Z (3 months ago)
- Topics: clickhouse, jaeger, jaegertracing, observability, opentelemetry
- Language: Go
- Homepage:
- Size: 227 KB
- Stars: 3
- Watchers: 3
- Forks: 1
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# Jaeger OpenTelemetry Clickhouse Backend
Jaeger gRPC backend (v1) compatible with the [OpenTelemetry Clickhouse exporter](https://github.com/open-telemetry/opentelemetry-collector-contrib/tree/main/exporter/clickhouseexporter). It provides a way of visualizing trace data stored in Clickhouse via the Jaeger Query frontend.
![Example trace from backend](assets/ui-example.png)
## Quickstart
Clone this repository and open a shell in the `examples` folder, then run:
```shell
docker-compose up
```
Access the Jaeger UI at [http://localhost:16686](http://localhost:16686).On first load, there will be no traces, but that will cause the backend to create and send traces to the collector. On refresh, you should see the backend service in the UI.
## Docker
Images are hosted on [Docker Hub](https://hub.docker.com/r/nextrevision/jaeger-otel-clickhouse-backend) and can be run with:
```shell
docker run --rm -it -e JOCB_DB_HOST=127.0.0.1 -e JOCB_DB_PORT=9000 -p 14482:14482 nextrevision/jaeger-otel-clickhouse-backend:latest
```## Config
Can be set by YAML file and the `-config` flag or by environment variable with the `JOCB` prefix.
| Env Var | YAML | Type | Required | Default | Example |
|-------------------------------------|--------------------------------|--------|----------|---------------|-------------------|
| `JOCB_DB_HOST` | `db_host` | string | true | | `127.0.0.1` |
| `JOCB_DB_PORT` | `db_port` | int | true | | `9000` |
| `JOCB_DB_USER` | `db_user` | string | true | `default` | `test_user` |
| `JOCB_DB_PASS` | `db_pass` | string | false | | `test_pass` |
| `JOCB_DB_NAME` | `db_name` | string | true | `otel` | `custom_database` |
| `JOCB_DB_TABLE` | `db_table` | string | true | `otel_traces` | `trace_data` |
| `JOCB_DB_CA_FILE` | `db_ca_file` | string | false | | `/ca.crt` |
| `JOCB_DB_TLS_ENABLED` | `db_tls_enabled` | bool | false | `false` | `true` |
| `JOCB_DB_TLS_INSECURE` | `db_tls_insecure` | bool | false | `false` | `true` |
| `JOCB_DB_MAX_OPEN_CONNS` | `db_max_open_conns` | int | false | | `10` |
| `JOCB_DB_MAX_IDLE_CONNS` | `db_max_idle_conns` | int | false | | `5` |
| `JOCB_DB_CONN_MAX_LIFETIME_MILLIS` | `db_conn_max_lifetime_millis` | int | false | | `3000` |
| `JOCB_DB_CONN_MAX_IDLE_TIME_MILLIS` | `db_conn_max_idle_time_millis` | int | false | | `1000` |
| `JOCB_ENABLE_TRACING` | `enable_tracing` | bool | false | `false` | `true` |
| `JOCB_PAD_TRACE_ID` | `pad_trace_id` | bool | false | `false` | `true` |### Pad Trace ID
If your trace provider exports using the old 16 character trace ID, you can set this field to pad the trace ID with 16 additional "0"s. If you are unsure, check your Clickhouse database and see how traces are being stored. If there are trace IDs padded with 16 characters, this should be enabled.
### Tracing
The backend has been instrumented with OpenTelemetry and can be configured to export traces via gRPC to an OTLP compatible endpoint. This can be enabled using the `JOCB_ENABLE_TRACING=true` environment variable and setting `OTEL_EXPORTER_OTLP_ENDPOINT` to the desired OTLP compatible address.
## Tag Search Syntax
I took the liberty to enhance the tag search expressivity with wildcards and regex patterns.
### Wildcards
In the "Tags" field, using a `%` character will result in a wildcard match using SQL `LIKE` grammar. The following is an example of a tag query and the resulting SQL:
```sql
# http.url=http%://duckduckgo.com
SELECT ... WHERE SpanAttributes['http.url'] LIKE 'http%://duckduckgo.com'
```If you wish to use a literal `%`, then escape it as `\\%`.
### Regex
In the "Tags" field, using the operator `=~` character will result in a regex match using the Clickhouse [match](https://clickhouse.com/docs/en/sql-reference/functions/string-search-functions#match) function. The following is an example of a tag query and the resulting SQL:
```sql
# http.url=~http://[duck]+go.com
SELECT ... WHERE match(SpanAttributes['http.url'], 'http://[duck]+go.com')
```## Development
Start the `clickhouse`, `otelcol` and `jaeger-query` services in the docker-compose example:
```shell
cd examples
docker-compose up -f docker-compose.dev.yml
```Start a development server with the following environment variables:
```shell
JOCB_DB_HOST=127.0.0.1
JOCB_DB_PORT=19000
JOCB_ENABLE_TRACING=true
OTEL_EXPORTER_OTLP_ENDPOINT=http://127.0.0.1:4317
```