-
Notifications
You must be signed in to change notification settings - Fork 30
OpenTracing API & IPFS #277
Comments
@jacobheun, @alanshaw getting this on your radar for the objectives in js-ipfs and js-libp2p error handling, monitoring and debugging. |
@frrist What are your thoughts on using OpenCensus which provides both the OpenTracing API and tags and metrics? |
OpenCensus looks really interesting (this is the first I've heard of it), it appears to do everything OpenTracing does, plus more. However, I haven't seen any information that says the OT and OC API's are compatible; I think they are similar concepts with different specs. I also don't see JavaScript listed under supported languages for OC, although there is a GH repo so maybe its on the way. What OT and OC would look like working together is a bit fuzzy to me - although I think it's probably doable. Have you played around with OC at all? |
sorry, I misspoke, OC tracing outputs are compatible with OT backends, which is the 'promise' of OT that the code you write to do tracing doesn't lock you into a particular tracing backend, to that extent OC provides that same.
There is currently
Technically, you would not use OT. OC makes use of OT's tracing format.
Yes, I have been playing around with it in ipfs-cluster. I added OC stats to the |
OpenTracing API
Goals from reading:
Why use OpenTracing?
Tracing can reconstruct the different journeys operations take as they propagate throughout a system. OpenTracing is a standard mechanism used to instrument tracing on a system without binding to any particular tracing vendor. This allows every component of a distributed system to be instrumented in isolation and for different tracing technologies to be swapped out via a single configuration change [1].
Some overloaded terms
What is OpenTracing?
What should I know about OpenTracing?
Terminology & Concepts
Everthing below is covered in the above links, this is an attempt at a summary
Trace
Span
http.method
orpeer.ipv4
file
or orerrorMessage
Reference
Model direct casual relationships between a child Span and a parent Span
ChildOf
FollowsFrom
Tracer
Span
's and understands how toInject
andExtract
them across process boundaries (Carrier)Span
Inject
SpanContext into a carrierExtract
SpanContext from a carrierCarrier
SpanContext
across process boundaries.TL;DR: A Trace is the story of an actions execution written and viewed with a Tracer where each chapter is a Span
Pictures and Diagrams
Causal relationships between Spans in a single Trace:
Temporal relationships between Spans in a single Trace:
Trace JSON snippet:
How Does go-ipfs Instrument OpenTracing?
Plugin Interface
(currently in
feat/opentrace
branch)github.com/ipfs/go-ipfs/plugin/tracer.go
go-jaeger-plugin
go-jaeger-plugin
implements the PluginTracer Interface, and configures a tracergithub.com/ipfs/go-jaeger-plugin/plugin/jaeger.go
Me made a tracer!
go-ipfs/plugins Initializer
(currently in
feat/opentrace
branch)The plugins initializer in
go-ipfs
will call the tracersInitTracer
method and set the returnedtracer
as theGlobalTracer
via an OpenTracing API call.github.com/ipfs/go-ipfs/plugin/loader/initializer.go
We set the tracer as the GlobalTracer!
ServeHTTP (Root Span Created)
(currently in
feat/opentrace
branch)When a request comes into the
ServeHTTP
method, arootSpan
is created, tagged accordingly, andFinish
'd when handling of the request is complete.We created a
rootSpan
and associated it with a context!go-log
Spans are created when Events are done. Because we set the
tracer
asGlobalTracer
earlier opentracing will create all traces using thattracer
. Since we previously associated a Span with a context inServeHTTP
any Spans created here that have been associated with that context will have references to other Spans created during the request.We can log with
go-log
and generatespan
s for traces with the GlobalTracer!What does this look like in practice?
ipfs add -r dir/
commandSpan
s with metadatarootSpan
with metadataSpan
with errorWhere do we go next?
The text was updated successfully, but these errors were encountered: