Skip to content

Commit

Permalink
adding documentation for using opentelemetry-distro (#1813)
Browse files Browse the repository at this point in the history
  • Loading branch information
alrex authored May 7, 2021
1 parent 81d80aa commit 3a0d38f
Show file tree
Hide file tree
Showing 4 changed files with 121 additions and 8 deletions.
20 changes: 14 additions & 6 deletions docs/examples/auto-instrumentation/README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,7 @@ Manually instrumented server
return "served"
Server not instrumented manually
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

``server_uninstrumented.py``

Expand All @@ -57,7 +57,7 @@ Server not instrumented manually
return "served"
Prepare
-----------
-------

Execute the following example in a separate virtual environment.
Run the following commands to prepare for auto-instrumentation:
Expand All @@ -69,7 +69,7 @@ Run the following commands to prepare for auto-instrumentation:
$ source auto_instrumentation/bin/activate
Install
------------
-------

Run the following commands to install the appropriate packages. The
``opentelemetry-instrumentation`` package provides several
Expand All @@ -90,7 +90,7 @@ a server as well as the process of executing an automatically
instrumented server.

Execute a manually instrumented server
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Execute the server in two separate consoles, one to run each of the
scripts that make up this example:
Expand Down Expand Up @@ -145,7 +145,7 @@ similar to the following example:
}
Execute an automatically instrumented server
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

Stop the execution of ``server_instrumented.py`` with ``ctrl + c``
and run the following command instead:
Expand Down Expand Up @@ -208,7 +208,7 @@ You can see that both outputs are the same because automatic instrumentation doe
exactly what manual instrumentation does.

Instrumentation while debugging
===============================
~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~

The debug mode can be enabled in the Flask app like this:

Expand All @@ -226,3 +226,11 @@ reloader. To run instrumentation while the debug mode is enabled, set the
if __name__ == "__main__":
app.run(port=8082, debug=True, use_reloader=False)
Additional resources
~~~~~~~~~~~~~~~~~~~~

In order to send telemetry to an OpenTelemetry Collector without doing any
additional configuration, read about the `OpenTelemetry Distro <../distro/README.html>`_
package.
104 changes: 104 additions & 0 deletions docs/examples/distro/README.rst
Original file line number Diff line number Diff line change
@@ -0,0 +1,104 @@
OpenTelemetry Distro
====================

In order to make using OpenTelemetry and auto-instrumentation as quick as possible without sacrificing flexibility,
OpenTelemetry distros provide a mechanism to automatically configure some of the more common options for users. By
harnessing their power, users of OpenTelemetry can configure the components as they need. The ``opentelemetry-distro``
package provides some defaults to users looking to get started, it configures:

- the SDK TracerProvider
- a BatchSpanProcessor
- the OTLP ``SpanExporter`` to send data to an OpenTelemetry collector

The package also provides a starting point for anyone interested in producing an alternative distro. The
interfaces implemented by the package are loaded by the auto-instrumentation via the ``opentelemetry_distro``
and ``opentelemetry_configurator`` entry points to configure the application before any other code is
executed.

In order to automatically export data from OpenTelemetry to the OpenTelemetry collector, installing the
package will setup all the required entry points.

.. code:: sh
$ pip install opentelemetry-distro[otlp] opentelemetry-instrumentation
Start the Collector locally to see data being exported. Write the following file:

.. code-block:: yaml
# /tmp/otel-collector-config.yaml
receivers:
otlp:
protocols:
grpc:
http:
exporters:
logging:
loglevel: debug
processors:
batch:
service:
pipelines:
traces:
receivers: [otlp]
exporters: [logging]
processors: [batch]
Then start the Docker container:

.. code-block:: sh
docker run -p 4317:4317 \
-v /tmp/otel-collector-config.yaml:/etc/otel-collector-config.yaml \
otel/opentelemetry-collector:latest \
--config=/etc/otel-collector-config.yaml
The following code will create a span with no configuration.

.. code:: python
# no_configuration.py
from opentelemetry import trace
with trace.get_tracer(__name__).start_as_current_span("foo"):
with trace.get_tracer(__name__).start_as_current_span("bar"):
print("baz")
Lastly, run the ``no_configuration.py`` with the auto-instrumentation:

.. code-block:: sh
$ opentelemetry-instrument python no_configuration.py
The resulting span will appear in the output from the collector and look similar to this:

.. code-block:: sh
Resource labels:
-> telemetry.sdk.language: STRING(python)
-> telemetry.sdk.name: STRING(opentelemetry)
-> telemetry.sdk.version: STRING(1.1.0)
-> service.name: STRING(unknown_service)
InstrumentationLibrarySpans #0
InstrumentationLibrary __main__
Span #0
Trace ID : db3c99e5bfc50ef8be1773c3765e8845
Parent ID : 0677126a4d110cb8
ID : 3163b3022808ed1b
Name : bar
Kind : SPAN_KIND_INTERNAL
Start time : 2021-05-06 22:54:51.23063 +0000 UTC
End time : 2021-05-06 22:54:51.230684 +0000 UTC
Status code : STATUS_CODE_UNSET
Status message :
Span #1
Trace ID : db3c99e5bfc50ef8be1773c3765e8845
Parent ID :
ID : 0677126a4d110cb8
Name : foo
Kind : SPAN_KIND_INTERNAL
Start time : 2021-05-06 22:54:51.230549 +0000 UTC
End time : 2021-05-06 22:54:51.230706 +0000 UTC
Status code : STATUS_CODE_UNSET
Status message :
2 changes: 1 addition & 1 deletion docs/getting_started/otlpcollector_example.py
Original file line number Diff line number Diff line change
Expand Up @@ -24,7 +24,7 @@

span_exporter = OTLPSpanExporter(
# optional
# endpoint:="myCollectorURL:4317",
# endpoint="myCollectorURL:4317",
# credentials=ChannelCredentials(credentials),
# headers=(("metadata", "metadata")),
)
Expand Down
3 changes: 2 additions & 1 deletion opentelemetry-distro/README.rst
Original file line number Diff line number Diff line change
Expand Up @@ -14,9 +14,10 @@ Installation
pip install opentelemetry-distro


This package provides entrypoints to configure OpenTelemetry
This package provides entrypoints to configure OpenTelemetry.

References
----------

* `OpenTelemetry Project <https://opentelemetry.io/>`_
* `Example using opentelemetry-distro <https://opentelemetry-python.readthedocs.io/en/latest/examples/distro/README.html>`_

0 comments on commit 3a0d38f

Please sign in to comment.