otel4s is an OpenTelemetry implementation for Scala. The design goal is to fully and faithfully implement the OpenTelemetry Specification atop Cats Effect.
-
otel4s provides APIs and implementations for metrics and tracing.
-
Core modules for JVM, Scala.js, and Scala Native offer an API with no-op implementations. These are appropriate for library instrumentation.
-
SDK modules provide working telemetry (only tracing, currently) for applications. SDK modules are implemented in Scala from scratch. Available for JVM, Scala.js, and Scala Native. The implementation remains experimental and some functionality may be lacking.
-
opentelemetry-java backend provided for the JVM. This provides working telemetry for applications.
The API is still highly experimental, but we are actively instrumenting various libraries and applications to check for fit. Don't put it in a binary-stable library yet, but we invite you to try it out and let us know what you think.
Module / Platform | JVM | Scala Native | Scala.js |
---|---|---|---|
otel4s-core |
✅ | ✅ | ✅ |
otel4s-sdk (tracing only) |
✅ | ✅ | ✅ |
otel4s-oteljava |
✅ | ❌ | ❌ |
If you develop an application and want to export the telemetry, use otel4s-oteljava
module.
If you develop a library, check out this recommendation.
@:select(build-tool)
@:choice(sbt)
Add settings to the build.sbt
:
libraryDependencies ++= Seq(
"org.typelevel" %% "otel4s-oteljava" % "@VERSION@", // <1>
"io.opentelemetry" % "opentelemetry-exporter-otlp" % "@OPEN_TELEMETRY_VERSION@" % Runtime, // <2>
"io.opentelemetry" % "opentelemetry-sdk-extension-autoconfigure" % "@OPEN_TELEMETRY_VERSION@" % Runtime // <3>
)
javaOptions += "-Dotel.java.global-autoconfigure.enabled=true" // <4>
@:choice(scala-cli)
Add directives to the *.scala
file:
//> using lib "org.typelevel::otel4s-oteljava:@VERSION@" // <1>
//> using lib "io.opentelemetry:opentelemetry-exporter-otlp:@OPEN_TELEMETRY_VERSION@" // <2>
//> using lib "io.opentelemetry:opentelemetry-sdk-extension-autoconfigure:@OPEN_TELEMETRY_VERSION@" // <3>
//> using `java-opt` "-Dotel.java.global-autoconfigure.enabled=true" // <4>
@:@
- Add the
otel4s-oteljava
library - Add an OpenTelemetry exporter. Without the exporter, the application will crash
- Add an OpenTelemetry autoconfigure extension
- Enable OpenTelemetry SDK autoconfigure mode
- Start tracing your application with Jaeger and Docker
- Implement tracing and metrics with Honeycomb
If you use a library that supports otel4s (eg Skunk) but do not want to use Open Telemetry, then you can place the No-op Tracer into implicit scope.
// via import
// import org.typelevel.otel4s.trace.Tracer.Implicits.noop
// via implicit val
import cats.effect.IO
import org.typelevel.otel4s.trace.Tracer
implicit val tracer: Tracer[IO] = Tracer.noop