SkyWalking Python Agent

SkyWalking-Python: The Python Agent for Apache SkyWalking, which provides the native tracing abilities for Python project.

SkyWalking: an APM(application performance monitor) system, especially designed for microservices, cloud native and container-based (Docker, Kubernetes, Mesos) architectures.

GitHub stars Twitter Follow

Build

Install

From Pypi

The Python agent module is published to Pypi, from where you can use pip to install:

# Install the latest version
pip install apache-skywalking

# Install a specific version x.y.z
# pip install apache-skywalking==x.y.z
pip install apache-skywalking==0.1.0  # For example, install version 0.1.0 no matter what the latest version is

From Source Codes

Refer to the FAQ.

Set up Python Agent

SkyWalking Python SDK requires SkyWalking 8.0+ and Python 3.5+.

If you want to try out the latest features that're not released yet, please refer to the guide to build from sources.

from skywalking import agent, config

config.init(collector='127.0.0.1:11800', service='your awesome service')
agent.start()

Alternatively, you can also pass the configurations via environment variables and you don't need to call config.init.

The supported environment variables are as follows:

Environment VariableDescriptionDefault
SW_AGENT_NAMEThe name of the Python servicePython Service Name
SW_AGENT_INSTANCEThe name of the Python service instanceRandomly generated
SW_AGENT_COLLECTOR_BACKEND_SERVICESThe backend OAP server address127.0.0.1:11800
SW_AGENT_PROTOCOLThe protocol to communicate with the backend OAP, http or grpc, we highly suggest using grpc in production as it's well optimized than httpgrpc
SW_AGENT_AUTHENTICATIONThe authentication token to verify that the agent is trusted by the backend OAP, as for how to configure the backend, refer to the yaml.not set
SW_AGENT_LOGGING_LEVELThe logging level, could be one of CRITICAL, FATAL, ERROR, WARN(WARNING), INFO, DEBUGINFO
SW_AGENT_DISABLE_PLUGINSThe name patterns in CSV pattern, plugins whose name matches one of the pattern won't be installed''
SW_MYSQL_TRACE_SQL_PARAMETERSIndicates whether to collect the sql parameters or notFalse
SW_MYSQL_SQL_PARAMETERS_MAX_LENGTHThe maximum length of the collected parameter, parameters longer than the specified length will be truncated512
SW_IGNORE_SUFFIXIf the operation name of the first span is included in this set, this segment should be ignored..jpg,.jpeg,.js,.css,.png,.bmp,.gif,.ico,.mp3,.mp4,.html,.svg
SW_FLASK_COLLECT_HTTP_PARAMSThis config item controls that whether the Flask plugin should collect the parameters of the request.false
SW_DJANGO_COLLECT_HTTP_PARAMSThis config item controls that whether the Django plugin should collect the parameters of the request.false
SW_HTTP_PARAMS_LENGTH_THRESHOLDWhen COLLECT_HTTP_PARAMS is enabled, how many characters to keep and send to the OAP backend, use negative values to keep and send the complete parameters, NB. this config item is added for the sake of performance.1024
SW_CORRELATION_ELEMENT_MAX_NUMBERMax element count of the correlation context.3
SW_CORRELATION_VALUE_MAX_LENGTHMax value length of correlation context element.128

Supported Libraries

There're some built-in plugins that support automatic instrumentation of Python libraries, the complete lists are as follow:

LibraryPlugin Name
http.serversw_http_server
urllib.requestsw_urllib_request
requestssw_requests
Flasksw_flask
PyMySQLsw_pymysql
Djangosw_django
redis-pysw_redis
kafka-pythonsw_kafka
tornadosw_tornado
pikasw_rabbitmq

API

Apart from the libraries that can be instrumented automatically, we also provide some APIs to enable manual instrumentation.

Create Spans

The code snippet below shows how to create entry span, exit span and local span.

from skywalking import Component
from skywalking.trace.context import SpanContext, get_context
from skywalking.trace.tags import Tag

context: SpanContext = get_context()  # get a tracing context
# create an entry span, by using `with` statement,
# the span automatically starts/stops when entering/exiting the context
with context.new_entry_span(op='https://github.com/apache') as span:
    span.component = Component.Flask
# the span automatically stops when exiting the `with` context

with context.new_exit_span(op='https://github.com/apache', peer='localhost:8080') as span:
    span.component = Component.Flask

with context.new_local_span(op='https://github.com/apache') as span:
    span.tag(Tag(key='Singer', val='Nakajima'))

Decorators

from time import sleep

from skywalking import Component
from skywalking.decorators import trace
from skywalking.trace.context import SpanContext, get_context

@trace()  # the operation name is the method name('some_other_method') by default
def some_other_method():
    sleep(1)


@trace(op='awesome')  # customize the operation name to 'awesome'
def some_method():
    some_other_method()


context: SpanContext = get_context()
with context.new_entry_span(op=str('https://github.com/apache/skywalking')) as span:
    span.component = Component.Flask
    some_method()

FAQs

Check the FAQ page or add the FAQs there.

For Developers

Steps to get an operational virtual environment:

  1. git clone https://github.com/apache/skywalking-python.git
  2. cd skywalking-python/tools/env (make sure you actually go into the directory since the scripts use relative paths)
  3. Run the script for your relevant OS to create a virtual environment folder in the project root (skywalking-python/venv) and install all the necessary requirements

Make sure that when the python command is executed on your workstation, the binary it references is python 3.5 or newer!

Steps after contributing

If your PR introduces the need for a new non-standard library which needs to be pulled via pip or if it removes the need for a previously-used library:

  1. navigate to /path/to/skywalking/agent/tools/env
  2. Execute the build_requirements script relevant to your OS.
  3. Double check the requirements.txt file in the project root to ensure that the changes have been reflected.

License

Apache 2.0