SkyWalking

SkyWalking is an important APM (Application Performance Monitoring) implementation in the Seata component.

Prerequisites

Before integrating SkyWalking into your Seata project, please make sure that the SkyWalking service has been started in the background. If you are not familiar with the basic usage of SkyWalking, you can refer to the SkyWalking Quick Start first. It is recommended to use SkyWalking version 8.6.0 or above.

Quick Start

The steps to integrate SkyWalking application performance monitoring into Seata are very simple. It can be roughly divided into “Compile & Configure” and “Access Monitoring” steps.

Compile & Configure

First, you need to download the Seata source code and execute the following command in the root directory of the source code:

mvn clean package -Dmaven.test.skip=true

Put seata/ext/apm-skywalking/target/seata-skywalking-{version}.jar into the SkyWalking probe plugin folder.

It is strongly recommended to use the latest version of Seata:

Access Monitoring

The integration of Seata client and server with SkyWalking is no different from other application services. You can refer to the SkyWalking Probe Configuration.

The important parameters involved in Seata are:

ParameterDescription
skywalking.plugin.seata.serverBoolean attribute, when set to true, indicates whether the application service is a Seata server
skywalking.plugin.jdbc.trace_sql_parametersBoolean attribute, when set to true, the application service records SQL parameters
skywalking.agent.service_nameString attribute, identifies the unique identifier of the application service in SkyWalking

Seata client probe parameters can refer to

  1. java -javaagent:{path}/skywalking-agent.jar -Dskywalking.agent.service_name=seata_biz -Dskywalking.plugin.jdbc.trace_sql_parameters=true -jar seata_biz.jar

Seata server probe parameters can refer to

  1. java -javaagent:{path}/skywalking-agent.jar -Dskywalking.agent.service_name=seata_tc -Dskywalking.plugin.jdbc.trace_sql_parameters=true -Dskywalking.plugin.seata.server=true -jar seata_tc.jar

Notes

  1. Currently, only non-batch processing (enableClientBatchSendRequest is false) distributed transaction mode is supported.