A Deep Dive Into Observability — Apache ShardingSphere Agent

Apache ShardingSphere
CodeX
Published in
5 min readMar 25, 2022

--

Apache ShardingSphere follows Database Plus — our community’s guiding development concept for creating a complete data service ecosystem that allows you to transform any database into a distributed database system, and easily enhance it with sharding, elastic scaling, data encryption features & more.

Users often need to monitor Apache ShardingSphere’s performance in a real application scenario to find specific problems.

It’s a given that Application Performance Monitoring (APM) can monitor and diagnose system performance by collecting, storing, and analyzing observable data. It also integrates functions such as performance metrics, tracing analysis, application topology mapping, etc.

It retrieves the observable data from system operations by utilizing Tracing, Metrics and Logging. Apache ShardingSphere provides the Observability function for users.

Purposes

Apache ShardingSphere allows developers to configure logging output. The main objective of the current Observability feature is to provide necessary metrics and tracing data for users.

Design

We chose the common Agent method to perfectly implement Observability, with ByteBuddy (a code generation library that allows developers to modify Java classes (arbitrary included) during application runtime without using a compiler and Java Agent.

We adpot the plugin-oriented design to better support different frameworks or systems with Metrics and Tracing. Accordingly, users are allowed to customize the feature or develop more business-specific components by themselves.

Currently, the Agent module of Apache ShardingSphere supports Prometheus, Zipkin, Jaeger, SkyWalking, and OpenTelemetry.

Example

In the following instance, we deploy Prometheus and Zipkin observable data plugins on Apache ShardingSphere-Proxy to showcase how to use the Apache ShardingSphere Agent module.

Step 1: Install the Required Software

  • prometheus-2.32.1.linux-amd64.tar.gz (https://prometheus.io/download)
  • zipkin-server-2.23.9-exec.jar (https://zipkin.io/pages/quickstart.html)
  • apache-shardingsphere-5.1.0-SNAPSHOT-shardingsphere-proxy-bin.tar.gz
  • apache-shardingsphere-5.1.0-SNAPSHOT-shardingsphere-agent-bin.tar.gz
  • MySQL 5.7.34

Step 2: Deploy

  • Port

Prometheus Server:9090

Zipkin Server:9411

Apache ShardingSphere-Proxy:3307

Apache ShardingSphere Agent(Prometheus Plugin):9000

Prometheus

First, add monitoring objects to Prometheus. In this case, we need to add the Apache ShardingSphere Agent port address 9000 to the Prometheus configuration file prometheus.yml.

vi prometheus.yml

Add the following code under static_configs in the file:

- targets: ["localhost:9000"]

Then, initiate:

./prometheus &

Zipkin

Zipkin is easier to use. Initiate it by input the following command in the Zipkin Server directory:

java -jar zipkin-server-2.23.9-exec.jar &

Apache ShardingSphere

To deploy Apache ShardingSphere-Proxy and Agent, please refer to the official related user guide.

Assuming Proxy and Agent are both in the /tmp directory, below are the specific Agent deployment steps:

  1. Modify Configurations

Modify the agent.yaml configuration file.

Then, initiate Prometheus and Zipkin plugins and change the Prometheus port data to 9000 in line with the above-mentioned port settings:

applicationName: shardingsphere-agentignoredPluginNames:- Jaeger- OpenTracing- OpenTelemetry- Loggingplugins:Prometheus:host:  "localhost"port: 9000props:JVM_INFORMATION_COLLECTOR_ENABLED : "true"Jaeger:host: "localhost"port: 5775props:SERVICE_NAME: "shardingsphere-agent"JAEGER_SAMPLER_TYPE: "const"JAEGER_SAMPLER_PARAM: "1"Zipkin:host: "localhost"port: 9411props:SERVICE_NAME: "shardingsphere-agent"URL_VERSION: "/api/v2/spans"SAMPLER_TYPE: "const"SAMPLER_PARAM: "1"OpenTracing:props:OPENTRACING_TRACER_CLASS_NAME: "org.apache.skywalking.apm.toolkit.opentracing.SkywalkingTracer"OpenTelemetry:props:otel.resource.attributes: "service.name=shardingsphere-agent"otel.traces.exporter: "zipkin"Logging:props:LEVEL: "INFO"

2. Add to Start Command

Modify the file /tmp/apache-shardingsphere-5.1.0-shardingsphere-proxy-bin/bin/start.sh and add the absolute path of Agent’s shardingsphere-agent.jar to the startup script.

Before

nohup java ${JAVA_OPTS} ${JAVA_MEM_OPTS} \-classpath ${CLASS_PATH} ${MAIN_CLASS} >> ${STDOUT_FILE} 2>&1 &

After

nohup java ${JAVA_OPTS} ${JAVA_MEM_OPTS} \-javaagent:/tmp/apache-shardingsphere-5.1.0-shardingsphere-agent-bin/shardingsphere-agent.jar \-classpath ${CLASS_PATH} ${MAIN_CLASS} >> ${STDOUT_FILE} 2>&1 &

3. Initiate

Now we’re ready to initiate them under the Proxy directory:

bin/start.sh

Step 3: Test Accesses

  1. Metrics and Tracing Data

We use config-sharding.yaml, the default sharding configuration scenario provided by Apache ShardingSphere-Proxy, to test access and display data.

  • Connect to the initiated ShardingSphere-Proxy with MySQL command lines.
  • Examine the data results in Prometheus Server and Zipkin Server

Query proxy_info and get the data results through Prometheus Web.

View Zipkin Web tracing information after connecting to the MySQL client:

  • Query data through MySQL command line:
  • Examine the data results of Prometheus Server and Zipkin Server

Query parse_sql_dml_select_total data results through Prometheus Web.

Query tracing information via Zipkin Web:

Through a careful search of Span, we can check the tracing status of SQL statement select * from t_order.

Topology Mapping

We cannot find topology mappings when we check dependencies through Zipkin Web.

So, we need to configure them:

  1. Download files

First, download the following Zipkin dependencies, and copy them to the lib directory of Proxy.

2. Modify Configurations

Configure the data source configuration file config-sharding.yaml, which is in the conf directory of the Proxy, and add the following configuration to the URL corresponding to the lower data source of the config-sharding.YAML dataSources node:

MySQL 5.x:statementInterceptors=brave.mysql.TracingStatementInterceptor

Or MySQL 8.x:queryInterceptors=brave.mysql8.TracingQueryInterceptor

  • Restart ShardingSphere-Proxy

After performing the same access test as before, we can view dependencies through Zipkin Web and see the following topology mappings:

Sampling Rate

The Observability plugin also enables users to set differnt sampling rate configured to suit different scenarios. Zipkin plugins support various sampling rate type configurations including const, counting, rate limiting, and boundary.

For scenarios with a high volume of requests, we suggest you to choose the boundary type and configure it with the appropriate sampling rate to reduce the collect volume of tracing data.

Zipkin:host: "localhost"port: 9411props:SERVICE_NAME: "shardingsphere-agent"URL_VERSION: "/api/v2/spans"SAMPLER_TYPE: "boundary"SAMPLER_PARAM: "0.001"

Summary

With the Observibility plugin compatible with many common monitoring frameworks and systems by default, users can easily monitor and manage Apache ShardingSphere.

In the future, we will continue to enhance the monitoring capability.

Apache ShardingSphere Open Source Project Links:

ShardingSphere Github

ShardingSphere Twitter

ShardingSphere Slack

Contributor Guideline

Co-Authors

Pingchuan JIANG

SphereEx Senior Middleware Engineer, Apache Tomcat & Apache ShardingSphere Contributor.

An open source technology enthusiast, Pingchuan devotes himself to developing SphereEx-Console and SphereEx-Boot.

Maolin JIANG

SphereEx Senior Middleware Engineer & Apache ShardingSphere Contributor.

--

--

Apache ShardingSphere
CodeX
Writer for

Distributed SQL transaction & query engine for data sharding, scaling, encryption, and more - on any database. https://linktr.ee/ApacheShardingSphere