Legacy Setup
You can always fall back to our traditional way of integration as introduced below, which is by importing SkyWalking into your project and starting the agent.
Defaults
By default, SkyWalking Python agent uses gRPC protocol to report data to SkyWalking backend,
in SkyWalking backend, the port of gRPC protocol is 11800
, and the port of HTTP protocol is 12800
,
You could configure collector_address
(or environment variable SW_AGENT_COLLECTOR_BACKEND_SERVICES
)
and set protocol
(or environment variable SW_AGENT_PROTOCOL
to one of
gprc
, http
or kafka
according to the protocol you would like to use.
Report data via gRPC protocol (Default)
For example, if you want to use gRPC protocol to report data, configure collector_address
(or environment variable SW_AGENT_COLLECTOR_BACKEND_SERVICES
) to <oap-ip-or-host>:11800
,
such as 127.0.0.1:11800
:
from skywalking import agent, config
config.init(collector_address='127.0.0.1:11800', service_name='your awesome service')
agent.start()
Report data via HTTP protocol
However, if you want to use HTTP protocol to report data, configure collector_address
(or environment variable SW_AGENT_COLLECTOR_BACKEND_SERVICES
) to <oap-ip-or-host>:12800
,
such as 127.0.0.1:12800
, further set protocol
(or environment variable SW_AGENT_PROTOCOL
to http
):
Remember you should install
skywalking-python
with extra requireshttp
,pip install "apache-skywalking[http]
.
from skywalking import agent, config
config.init(collector_address='127.0.0.1:12800', service_name='your awesome service', protocol='http')
agent.start()
Report data via Kafka protocol
Finally, if you want to use Kafka protocol to report data, configure kafka_bootstrap_servers
(or environment variable SW_KAFKA_REPORTER_BOOTSTRAP_SERVERS
) to kafka-brokers
,
such as 127.0.0.1:9200
, further set protocol
(or environment variable SW_AGENT_PROTOCOL
to kafka
):
Remember you should install
skywalking-python
with extra requireskafka
,pip install "apache-skywalking[kafka]"
.
from skywalking import agent, config
config.init(kafka_bootstrap_servers='127.0.0.1:9200', service_name='your awesome service', protocol='kafka')
agent.start()
Alternatively, you can also pass the configurations via environment variables (such as SW_AGENT_NAME
, SW_AGENT_COLLECTOR_BACKEND_SERVICES
, etc.) so that you don’t need to call config.init
.
All supported environment variables can be found in the Environment Variables List.