|
| 1 | +from __future__ import absolute_import |
| 2 | + |
1 | 3 | import time
|
2 |
| -from basictracer import BasicTracer |
3 |
| -import instana.recorder as r |
4 |
| -import opentracing as ot |
5 |
| -import instana |
6 |
| -import instana.options as o |
7 | 4 |
|
8 |
| -from instana.util import generate_id |
9 |
| -from instana.span import InstanaSpan |
| 5 | +import opentracing as ot |
| 6 | +from basictracer import BasicTracer |
10 | 7 | from basictracer.context import SpanContext
|
11 |
| -from instana.http_propagator import HTTPPropagator |
12 |
| -from instana.text_propagator import TextPropagator |
| 8 | + |
| 9 | +from . import sensor |
| 10 | +from . import options as o |
| 11 | +from . import recorder as r |
| 12 | +from .http_propagator import HTTPPropagator |
| 13 | +from .span import InstanaSpan |
| 14 | +from .text_propagator import TextPropagator |
| 15 | +from .util import generate_id |
13 | 16 |
|
14 | 17 |
|
15 | 18 | class InstanaTracer(BasicTracer):
|
16 | 19 | sensor = None
|
17 | 20 | cur_ctx = None
|
18 | 21 |
|
19 | 22 | def __init__(self, options=o.Options()):
|
20 |
| - self.sensor = instana.global_sensor |
| 23 | + self.sensor = sensor.get_sensor() |
21 | 24 | super(InstanaTracer, self).__init__(
|
22 | 25 | r.InstanaRecorder(self.sensor), r.InstanaSampler())
|
23 | 26 |
|
@@ -98,4 +101,21 @@ def init(options):
|
98 | 101 | No longer in use.
|
99 | 102 | To be removed in next major release.
|
100 | 103 | """
|
101 |
| - return instana.internal_tracer |
| 104 | + return internal_tracer |
| 105 | + |
| 106 | +def get_tracer(): |
| 107 | + return internal_tracer |
| 108 | + |
| 109 | + |
| 110 | +# The global OpenTracing compatible tracer used internally by |
| 111 | +# this package. |
| 112 | +# |
| 113 | +# Usage example: |
| 114 | +# |
| 115 | +# import instana |
| 116 | +# instana.internal_tracer.start_span(...) |
| 117 | +# |
| 118 | +internal_tracer = InstanaTracer() |
| 119 | + |
| 120 | +# Set ourselves as the tracer. |
| 121 | +ot.tracer = internal_tracer |
0 commit comments