@rmfitzpatrick/opentracing
v0.14.2-sm0
Published
[![Build Status][ci-img]][ci] [![Coverage Status][cov-img]][cov] [![NPM Published Version][npm-img]][npm] ![Node Version][node-img]
Downloads
1
Readme
OpenTracing API for JavaScript
This library is a JavaScript implementation of Open Tracing API. It is intended for use both on the server and in the browser.
Required Reading
To fully understand this platform API, it's helpful to be familiar with the OpenTracing project and terminology more specifically.
Quick Start
Install the package using npm
:
npm install --save opentracing
Example
The package contains an example using a naive MockTracer
implementation. To run the example:
npm run example
The output should look something like:
Spans:
parent_span - 1521ms
tag 'custom':'tag value'
tag 'alpha':'1000'
child_span - 503ms
tag 'alpha':'200'
tag 'beta':'50'
Code snippet
In your JavaScript code, add instrumentation to the operations to be tracked. This is composed primarily of using "spans" around operations of interest and adding log statements to capture useful data relevant to those operations.
const http = require('http');
const opentracing = require('opentracing');
// NOTE: the default OpenTracing tracer does not record any tracing information.
// Replace this line with the tracer implementation of your choice.
const tracer = new opentracing.Tracer();
const span = tracer.startSpan('http_request');
const opts = {
host : 'example.com',
method: 'GET',
port : '80',
path: '/',
};
http.request(opts, res => {
res.setEncoding('utf8');
res.on('error', err => {
// assuming no retries, mark the span as failed
span.setTag(opentracing.Tags.ERROR, true);
span.log({'event': 'error', 'error.object': err, 'message': err.message, 'stack': err.stack});
span.finish();
});
res.on('data', chunk => {
span.log({'event': 'data_received', 'chunk_length': chunk.length});
});
res.on('end', () => {
span.log({'event': 'request_end'});
span.finish();
});
}).end();
As noted in the source snippet, the default behavior of the opentracing
package is to act as a "no op" implementation. To capture and make the tracing data actionable, the tracer
object should be initialized with the OpenTracing implementation of your choice as in the pseudo-code below:
const CustomTracer = require('tracing-implementation-of-your-choice');
const tracer = new CustomTracer();
Usage in the browser
The package contains two bundles built with webpack that can be included using a standard <script>
tag. The library will be exposed under the global opentracing
namespace:
dist/opentracing-browser.min.js
- minified, no runtime checksdist/opentracing-browser.js
- debug version with runtime checks
Usage with TypeScript
Since the source is written in TypeScript, if you are using TypeScript, you can just npm install
the package and it will work out of the box.
This is especially useful for implementors who want to type check their implementation with the base interface.
Global tracer
The library also provides a global singleton tracer for convenience. This can be set and accessed via the following:
opentracing.initGlobalTracer(new CustomTracer());
const tracer = opentracing.globalTracer();
Note: globalTracer()
returns a wrapper on the actual tracer object. This is done for the convenience of use as it ensures that the function will always return a non-null object. This can be helpful in cases where it is difficult or impossible to know precisely when initGlobalTracer
is called (for example, when writing a utility library that does not control the initialization process). For more precise control, individual Tracer
objects can be used instead of the global tracer.
Span manager (experimental)
This library supports span activation in the spirit of the Scope Manager draft RFC.
If neither childOf
nor references
is specified, create spans are children of the activated span.
The intent of SpanManager
is that it remains active within the executed function and its transitive call graph. Ideally, this applies to both synchronous and asynchronous calls.
tracer.activeSpan() // null
tracer.activate(span, () => {
tracer.activeSpan() // span
setTimeout(() => {
tracer.activeSpan() // span
}, 0);
(async () => {
tracer.activeSpan() // span
})();
});
tracer.activeSpan() // null
JavaScript support for continuation local storage is a patchwork. This library includes simple wrappers around a few common APIs for continuation contexts.
ZoneSpanManger
This uses Zone.js. (See the associated Zone ES TC39 proposal.) It includes support for most common APIs: Web, Node.js, Electron, RxJS. Async syntax (async/await) is not supported. I.e. you should target ES 2015 or earlier syntax.
import 'zone.js';
import { ZoneSpanManager } from 'opentracing/zone_span_manager';
new ZoneSpanManager();
AsyncHookSpanManager
This uses the Node.js async_hooks API, available in Node.js 8.1.x+.
import { AsyncHookSpanManager } from 'opentracing/async_hook_span_manager';
new AsyncHookSpanManager();
AsyncWrapSpanManager
This uses async-hook-jl which patches the Node.js AsyncWrap API, available in Node.js 0.11.x - 7.x.x. Though without futher transpilation async-hook-jl requires Node.js 4.x.x+.
import { AsyncWrapSpanManager } from 'opentracing/async_wrap_span_manager';
new AsyncWrapSpanManager();
API Documentation
There is a hosted copy of the current generated ESDoc API Documentation here.
Contributing & developer information
See the OpenTracing website for general information on contributing to OpenTracing.
The project is written in TypeScript and built using a npm scripts. Run:
npm run build
creates the compiled, distributable JavaScript code in./lib
npm run watch
incrementally compiles on file changesnpm run webpack
creates the bundles for the browser in./dist
npm test
runs the testsnpm run typedoc
generates the documentation in./typedoc
OpenTracing tracer implementations
This section is intended for developers wishing to implement their own tracers. Developers who simply wish to use OpenTracing can safely ignore this information.
Custom tracer implementation
Implementations can subclass opentracing.Trace
, opentracing.Span
, and the other API classes to build an OpenTracing tracer and implement the underscore prefixed methods such as _addTag
to pick up a bit of common code implemented in the base classes.
API compatibility testing
If mocha
is being used for unit testing, test/api_compatibility
can be used to test the custom tracer. The file exports a single function that expects as an argument a function that will return a new instance of the tracer.
const apiCompatibilityChecks = require('opentracing/lib/test/api_compatibility.js').default;
apiCompatibilityChecks(() => new CustomTracer());
LICENSE
Apache License 2.0
MockTracer
A minimal example tracer is provided in the src/mock_tracer
directory of the source code.