Commit graph

574 commits

Author SHA1 Message Date
Simon Cruanes
05ef03b39d
Span.record_exception must also set the span status to error 2026-03-05 10:22:57 -05:00
Simon Cruanes
e2fe0f6683
dune shenanigan 2026-03-05 10:11:24 -05:00
Simon Cruanes
c442f3b818
batch: update n_dropped correctly; also self_debug in Emitter_batch 2026-03-04 13:16:40 -05:00
Simon Cruanes
31190a3606
providers: self debug at installation 2026-03-04 13:11:25 -05:00
Simon Cruanes
875101de9b
debug in bounded queue sync 2026-03-04 13:11:04 -05:00
Simon Cruanes
4a097759d3
revert to no batching by default in Provider_config 2026-03-03 20:08:10 -05:00
Simon Cruanes
20e395abf4
fix span: missign checks for dummy span 2026-03-03 17:52:30 -05:00
Simon Cruanes
7c1eb2321b
fix self_trace by just relying on Trace_provider 2026-03-03 17:46:30 -05:00
Simon Cruanes
d86b883c70
clients: setup self-debug as well 2026-03-03 17:16:04 -05:00
Simon Cruanes
f1f379d2e1
client: use self-debug and new provider config 2026-03-03 17:15:53 -05:00
Simon Cruanes
df643c9af6
add self_debug and provider_config 2026-03-03 17:10:19 -05:00
Simon Cruanes
478fe1da7b
otel.trace: have a single collector that always use current *_provider
just use the current Trace_provider.() (resp Log, Metrics) to emit a
span (resp log, metric). Simpler, and we rely on a global exporter
anyway.
2026-03-03 15:17:27 -05:00
Simon Cruanes
fa14ddf1f8
helpers to emit in *_provider 2026-03-03 15:14:32 -05:00
Simon Cruanes
a514ff8fe2
compat 4.08 2026-02-27 14:57:32 -05:00
Simon Cruanes
e3da59dd97
per signal provider, update to trace 0.12 2026-02-27 14:56:21 -05:00
Simon Cruanes
210b7991c9
rework tracer/meter/logger interfaces
- Meter is new, and makes more sense than
Metrics_callbacks/Metrics_emitter
- Instrument in core, with some basic counters, gauges, and histograms,
+ the possibility to do one's own
2026-02-20 12:31:15 -05:00
Simon Cruanes
d5f6b564db
shortcut in clock 2026-02-20 08:55:50 -05:00
Simon Cruanes
cb53b54b00
trace: expose the OTEL span 2026-02-19 15:29:56 -05:00
Simon Cruanes
07070e3d4a emitter: add self_metrics, track batch n_dropped, sampler rate 2026-02-17 20:59:58 -05:00
Simon Cruanes
71bb7d1996 various fixes 2026-02-17 20:59:58 -05:00
Simon Cruanes
33a0ee69ba
refactor: extract should_retry 2026-02-15 15:35:15 -05:00
Simon Cruanes
a44c50581b
Support http/json protocol, carry protocol to HTTP emitter
- Regenerate proto bindings with yojson support
- Add JSON encoding path in Resource_signal.Encode
- Pass protocol from config to generic_http_consumer
- Set Content-Type/Accept headers based on protocol
- Remove hardcoded protobuf headers from all HTTP client implementations
- Add yojson dependency
2026-02-15 15:35:15 -05:00
Simon Cruanes
a43587f2a6
rename hmap keys with more consistent scheme 2026-02-15 15:35:08 -05:00
Simon Cruanes
e9485c97da
Add retry with exponential backoff to HTTP client
- Add retry_max_attempts, retry_initial_delay_ms, retry_max_delay_ms, retry_backoff_multiplier to config
- Retry on network failures, 5xx errors, 429 (rate limit), 408 (timeout)
- No retry on 4xx client errors or user interrupt (Sysbreak)
- Default: 3 attempts, 100ms initial delay, 5s max delay, 2x multiplier
- Uses existing IO.sleep_s from generic_io
2026-02-15 15:17:27 -05:00
Simon Cruanes
e2aa473cf9
slight refactor 2026-02-15 15:08:30 -05:00
Simon Cruanes
8b9ea57a02
tweaks 2026-02-13 20:38:03 -05:00
Simon Cruanes
649d4b8aa8
handle sdk_disabled in all clients 2026-02-12 21:33:35 -05:00
Simon Cruanes
5114b6a8e7
client ocurl: handle config.sdk_disabled 2026-02-12 21:27:20 -05:00
Simon Cruanes
69d1d512e3
add missing OTEL env variables
- Rename http_config to exporter_config with deprecated alias
- add OTEL_SDK_DISABLED support (sdk_disabled field)
- add OTEL_EXPORTER_OTLP_PROTOCOL support (Http_protobuf | Http_json)
- add OTEL_LOG_LEVEL support (log_level field replacing debug bool)
- add OTEL_EXPORTER_OTLP_TIMEOUT and per-signal timeout variants
- add per-signal headers
(OTEL_EXPORTER_OTLP_{TRACES,METRICS,LOGS}_HEADERS)
- add OTEL_SERVICE_NAME support

also remove some globals and put most config in `exporter_config.ml`,
which is no longer a private record.
2026-02-12 21:04:28 -05:00
Simon Cruanes
21e799ae61 Fix ezcurl 0.3 compatibility issue
The ezcurl library changed its client type from Curl.t to Ezcurl_core.t
(an unboxed record type) in version 0.3. Updated both sync and lwt
implementations to use the correct type and module functions.
2026-02-08 07:03:43 +00:00
Simon Cruanes
1ebd474423 fix: critical bugs found in code review
Bug #1: Fix worker count logic in generic_consumer
- Was: min 2 (max 500 n_workers) - always created 2 workers
- Now: max 2 (min 500 n_workers) - properly clamps between 2-500
- Impact: Worker configuration was completely ignored

Bug #2: Handle missing dot in __FUNCTION__ name
- Added exception handling for String.rindex in trace span creation
- Prevents crash when tracing top-level or non-module functions
- Uses option type for module_path when no dot is present
- Scoped try/catch to only parsing logic
2026-02-08 06:16:05 +00:00
Simon Cruanes
c29ac75a82
opentelemetry.trace: expose sum and hist metrics 2026-01-21 22:15:23 -05:00
Simon Cruanes
4183254546
update trace, fix opentelemetry.trace 2026-01-21 22:00:08 -05:00
Simon Cruanes
0c119c3eff
details 2026-01-20 00:15:31 -05:00
Simon Cruanes
26e70ed1af
refactor trace: adapt to newer trace 0.99
no more global state 🥳
2026-01-20 00:15:31 -05:00
Simon Cruanes
96aef5e021
use a separate ambient-context library 2026-01-20 00:15:31 -05:00
Simon Cruanes
610244aad4
doc 2026-01-20 00:15:30 -05:00
Simon Cruanes
696a5d4b91
tidy up src/lib 2026-01-20 00:15:30 -05:00
Simon Cruanes
f31062a602
rename batching modules 2026-01-20 00:15:30 -05:00
Simon Cruanes
31aadebfd6
typo 2026-01-20 00:15:30 -05:00
Simon Cruanes
f208a87eb8
remove Rpool, unused 2026-01-20 00:15:30 -05:00
Simon Cruanes
4f6334dac0
add Emitter_sample 2026-01-20 00:15:30 -05:00
Simon Cruanes
843d10dae1
detail 2026-01-20 00:15:30 -05:00
Simon Cruanes
d2d5b33751
add Emitter_limit_interval 2026-01-20 00:15:30 -05:00
Simon Cruanes
3ba0523227
details on Interval_limiter 2026-01-20 00:15:29 -05:00
Simon Cruanes
008ae6ddfd
add Emitter_add_batching to client library
fronting an emitter with a batch belongs in its own module
2026-01-20 00:15:29 -05:00
Simon Cruanes
07d8357cfb
docs 2026-01-20 00:15:29 -05:00
Simon Cruanes
513aafe6e8
span: carry flags over to span_link 2026-01-20 00:15:29 -05:00
Simon Cruanes
2d6ec5c0f6
remove temporary code in ambient-context 2026-01-20 00:15:29 -05:00
Simon Cruanes
cdd1289c1d
compat 4.08 2026-01-20 00:15:29 -05:00