Launcher, Configuration Layer for OpenTelemetry
Project description
Launcher, an OpenTelemetry Configuration Layer 🚀
NOTE: This is in beta and is expected to GA in Fall 2020.
What is Launcher?
Launcher is a configuration layer that chooses default values for configuration options that many OpenTelemetry users want. It provides a single function in each language to simplify discovery of the options and components available to users. The goal of Launcher is to help users that aren't familiar with OpenTelemetry quickly ramp up on what they need to get going and instrument.
Getting started
pip install opentelemetry-launcher
Configure
Minimal setup
from opentelemetry.launcher import configure_opentelemetry
from opentelemetry import trace
configure_opentelemetry(
service_name="service-123",
access_token="my-token", # optional
)
tracer = trace.get_tracer(__name__)
with tracer.start_as_current_span("foo") as span:
span.set_attribute("attr1", "valu1")
with tracer.start_as_current_span("bar"):
with tracer.start_as_current_span("baz"):
print("Hello world from OpenTelemetry Python!")
Additional tracer options
configure_opentelemetry(
service_name="service-123",
service_version="1.2.3",
access_token="my-token",
span_exporter_endpoint="ingest.lightstep.com:443",
metric_exporter_endpoint="ingest.lightstep.com:443/metrics",
log_level=debug,
span_exporter_insecure=False,
metric_exporter_insecure=False,
)
Usage with Auto Instrumentation
OpenTelemetry Python includes a command that allows the user to automatically instrument certain third party libraries. Here is an example that shows how to use this launcher with auto instrumentation.
First, create a new virtual environment:
cd ~
mkdir auto_instrumentation
virtualenv auto_instrumentation
source auto_instrumentation/bin/activate
pip install opentelemetry-launcher
pip install requests
pip install flask
opentelemetry-bootstrap -a install
Once that is done, clone the opentelemetry-python
repo to get the example code:
git clone git@github.com:open-telemetry/opentelemetry-python.git
cd opentelemetry-python
Set the environment variables:
export LS_SERVICE_NAME=auto-instrumentation-testing
export LS_ACCESS_TOKEN=<the access token>
Run the server:
cd docs/examples/auto-instrumentation
opentelemetry-instrument python server_uninstrumented.py
Run the client in a separate console:
cd docs/examples/auto-instrumentation
python client.py testing
This should produce spans that can be captured in the Lightstep Explorer Web UI.
Configuration Options
Config | Env Variable | Required | Default |
---|---|---|---|
service_name | LS_SERVICE_NAME | y | - |
service_version | LS_SERVICE_VERSION | n | unknown |
access_token | LS_ACCESS_TOKEN | n | - |
span_exporter_endpoint | OTEL_EXPORTER_OTLP_SPAN_ENDPOINT | n | ingest.lightstep.com:443 |
span_exporter_insecure | OTEL_EXPORTER_OTLP_SPAN_INSECURE | n | False |
metric_exporter_endpoint | OTEL_EXPORTER_OTLP_METRIC_ENDPOINT | n | ingest.lightstep.com:443/metrics |
metric_exporter_insecure | OTEL_EXPORTER_OTLP_METRIC_INSECURE | n | False |
propagator | OTEL_PROPAGATORS | n | b3 |
resource_attributes | OTEL_RESOURCE_ATTRIBUTES | n | - |
log_level | OTEL_LOG_LEVEL | n | error |
Principles behind Launcher
100% interoperability with OpenTelemetry
One of the key principles behind putting together Launcher is to make lives of OpenTelemetry users easier, this means that there is no special configuration that requires users to install Launcher in order to use OpenTelemetry. It also means that any users of Launcher can leverage the flexibility of configuring OpenTelemetry as they need.
Opinionated configuration
Although we understand that not all languages use the same format for configuration, we find this annoying. We decided that Launcher would allow users to use the same configuration file across all languages. In this case, we settled for YAML
as the format, which was inspired by the OpenTelemetry Collector.
Validation
Another decision we made with launcher is to provide end users with a layer of validation of their configuration. This provides us the ability to give feedback to our users faster, so they can start collecting telemetry sooner.
Start using it today in Go, Java, Javascript and Python and let us know what you think!
Made with @ Lightstep
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file opentelemetry-launcher-0.13b0.tar.gz
.
File metadata
- Download URL: opentelemetry-launcher-0.13b0.tar.gz
- Upload date:
- Size: 9.6 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.49.0 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | 349bbb7bba90cee54219c2272845d0edb81ef414f143a957b7e83189b7058b93 |
|
MD5 | c1b6bc27c53a23ea2801d8203ea93da4 |
|
BLAKE2b-256 | 740948cfed5084ea2b3df6b789d6b8d85d6067c44fd8ae3fc16a27a0bb92243e |
File details
Details for the file opentelemetry_launcher-0.13b0-py3-none-any.whl
.
File metadata
- Download URL: opentelemetry_launcher-0.13b0-py3-none-any.whl
- Upload date:
- Size: 13.3 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/3.2.0 pkginfo/1.5.0.1 requests/2.24.0 setuptools/47.1.0 requests-toolbelt/0.9.1 tqdm/4.49.0 CPython/3.8.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | eb6db79fdf90d5992b3eb075a672f1d670f2db711fa96259b7bda93081efdc42 |
|
MD5 | ffb71f6e33b825a622eca58f82a206d8 |
|
BLAKE2b-256 | 9e2204e3027aac944b574db5fa337e281c64d0cb6ebab6bfd0f96ef07c0356a8 |