系統要求:CentOS 7.2 64 位操作系統
配置 Java 環境
安裝 JDK
Zipkin 使用 Java8
yum install java-1.8.0-openjdk* -y
安裝完成后,查看是否安裝成功:
java -version
安裝 Zipkin
新建目錄
mkdir -p /data/release/zipkin && cd "$_"
下載 Zipkin
wget -O zipkin.jar 'https://search.maven.org/remote_content?g=io.zipkin.java&a=zipkin-server&v=LATEST&c=exec'
啟動 Zipkin
java -jar zipkin.jar
Zipkin 默認監聽 9411 端口, 使用瀏覽器訪問 http://118.89.65.22:9411 即可看到 Zipkin 自帶的圖形化界面(外網:請確認此CVM有外網IP且安全組已開通9411端口)。
配置 MySQL 數據持久化方案
Zipkin 支持的持久化方案很多,如: Cassandra, MySQL, Elasticsearch。本實驗使用 MySQL 5.7 作為數據持久化方案。
安裝 MySQL 5.7
使用 Ctrl + C
退出上個步驟的 Java 進程並下載 rmp 包
wget http://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
安裝 rpm 包
rpm -Uvh mysql57-community-release-el7-9.noarch.rpm
安裝 MySQL
yum install mysql-community-server -y
啟動 MySQL 服務
systemctl start mysqld.service
設置 MySQL 密碼
獲取 root 臨時密碼(下面命令中的密碼是教程為您自動生成的,為了方便實驗的進行,不建議使用其它密碼。如果設置其它密碼,請把密碼記住,在后續的步驟會使用到)
grep 'temporary password' /var/log/mysqld.log | awk '{print $NF}'
使用上一步的獲得的臨時密碼登入 MySQL
mysql -uroot -p
設置 MySQL 賬戶 root 密碼
ALTER USER 'root'@'localhost' IDENTIFIED BY 'Xx$Zipkin2017';
退出 MySQL, 回到 Bash shell
exit;
初始化 Zipkin 數據庫
編寫初始化腳本
請在 /data/release/zipkin
目錄下創建 zipkin_init.sql,參考下面的內容。
1 CREATE TABLE IF NOT EXISTS zipkin_spans ( 2 `trace_id_high` BIGINT NOT NULL DEFAULT 0 COMMENT 'If non zero, this means the trace uses 128 bit traceIds instead of 64 bit', 3 `trace_id` BIGINT NOT NULL, 4 `id` BIGINT NOT NULL, 5 `name` VARCHAR(255) NOT NULL, 6 `parent_id` BIGINT, 7 `debug` BIT(1), 8 `start_ts` BIGINT COMMENT 'Span.timestamp(): epoch micros used for endTs query and to implement TTL', 9 `duration` BIGINT COMMENT 'Span.duration(): micros used for minDuration and maxDuration query' 10 ) ENGINE=InnoDB ROW_FORMAT=COMPRESSED CHARACTER SET=utf8 COLLATE utf8_general_ci; 11 12 ALTER TABLE zipkin_spans ADD UNIQUE KEY(`trace_id_high`, `trace_id`, `id`) COMMENT 'ignore insert on duplicate'; 13 ALTER TABLE zipkin_spans ADD INDEX(`trace_id_high`, `trace_id`, `id`) COMMENT 'for joining with zipkin_annotations'; 14 ALTER TABLE zipkin_spans ADD INDEX(`trace_id_high`, `trace_id`) COMMENT 'for getTracesByIds'; 15 ALTER TABLE zipkin_spans ADD INDEX(`name`) COMMENT 'for getTraces and getSpanNames'; 16 ALTER TABLE zipkin_spans ADD INDEX(`start_ts`) COMMENT 'for getTraces ordering and range'; 17 18 CREATE TABLE IF NOT EXISTS zipkin_annotations ( 19 `trace_id_high` BIGINT NOT NULL DEFAULT 0 COMMENT 'If non zero, this means the trace uses 128 bit traceIds instead of 64 bit', 20 `trace_id` BIGINT NOT NULL COMMENT 'coincides with zipkin_spans.trace_id', 21 `span_id` BIGINT NOT NULL COMMENT 'coincides with zipkin_spans.id', 22 `a_key` VARCHAR(255) NOT NULL COMMENT 'BinaryAnnotation.key or Annotation.value if type == -1', 23 `a_value` BLOB COMMENT 'BinaryAnnotation.value(), which must be smaller than 64KB', 24 `a_type` INT NOT NULL COMMENT 'BinaryAnnotation.type() or -1 if Annotation', 25 `a_timestamp` BIGINT COMMENT 'Used to implement TTL; Annotation.timestamp or zipkin_spans.timestamp', 26 `endpoint_ipv4` INT COMMENT 'Null when Binary/Annotation.endpoint is null', 27 `endpoint_ipv6` BINARY(16) COMMENT 'Null when Binary/Annotation.endpoint is null, or no IPv6 address', 28 `endpoint_port` SMALLINT COMMENT 'Null when Binary/Annotation.endpoint is null', 29 `endpoint_service_name` VARCHAR(255) COMMENT 'Null when Binary/Annotation.endpoint is null' 30 ) ENGINE=InnoDB ROW_FORMAT=COMPRESSED CHARACTER SET=utf8 COLLATE utf8_general_ci; 31 32 ALTER TABLE zipkin_annotations ADD UNIQUE KEY(`trace_id_high`, `trace_id`, `span_id`, `a_key`, `a_timestamp`) COMMENT 'Ignore insert on duplicate'; 33 ALTER TABLE zipkin_annotations ADD INDEX(`trace_id_high`, `trace_id`, `span_id`) COMMENT 'for joining with zipkin_spans'; 34 ALTER TABLE zipkin_annotations ADD INDEX(`trace_id_high`, `trace_id`) COMMENT 'for getTraces/ByIds'; 35 ALTER TABLE zipkin_annotations ADD INDEX(`endpoint_service_name`) COMMENT 'for getTraces and getServiceNames'; 36 ALTER TABLE zipkin_annotations ADD INDEX(`a_type`) COMMENT 'for getTraces'; 37 ALTER TABLE zipkin_annotations ADD INDEX(`a_key`) COMMENT 'for getTraces'; 38 ALTER TABLE zipkin_annotations ADD INDEX(`trace_id`, `span_id`, `a_key`) COMMENT 'for dependencies job'; 39 40 CREATE TABLE IF NOT EXISTS zipkin_dependencies ( 41 `day` DATE NOT NULL, 42 `parent` VARCHAR(255) NOT NULL, 43 `child` VARCHAR(255) NOT NULL, 44 `call_count` BIGINT 45 ) ENGINE=InnoDB ROW_FORMAT=COMPRESSED CHARACTER SET=utf8 COLLATE utf8_general_ci; 46 47 ALTER TABLE zipkin_dependencies ADD UNIQUE KEY(`day`, `parent`, `child`);
登錄 Mysql
mysql -u root --password='Xx$Zipkin2017'
創建 Zipkin 數據庫
create database zipkin;
切換數據庫
use zipkin;
初始化表及索引
source /data/release/zipkin/zipkin_init.sql
執行以下命令會看到zipkin_annotations
, zipkin_dependencies
, zipkin_spans
三張數據表,說明初始化成功了
show tables;
退出 MySQL, 回到 Bash shell
exit
啟動 Zipkin
注: 此處默認使用實驗生成的密碼
cd /data/release/zipkin STORAGE_TYPE=mysql MYSQL_HOST=localhost MYSQL_TCP_PORT=3306 MYSQL_DB=zipkin MYSQL_USER=root MYSQL_PASS='Xx$Zipkin2017' \ nohup java -jar zipkin.jar &
創建具有數據上報能力的Demo
搭建 NodeJS 環境
curl --silent --location https://rpm.nodesource.com/setup_8.x | sudo bash - yum install nodejs -y
創建Demo目錄
創建/data/release/service_a目錄
mkdir -p /data/release/service_a && cd "$_"
使用 NPM 安裝相關依賴
請在 /data/release/service_a
目錄下創建並編輯 package.json,參考下面的內容。
1 { 2 "name": "service_a", 3 "version": "1.0.0", 4 "description": "", 5 "main": "index.js", 6 "scripts": {}, 7 "author": "", 8 "license": "ISC", 9 "dependencies": { 10 "express": "^4.15.3", 11 "zipkin": "^0.7.2", 12 "zipkin-instrumentation-express": "^0.7.2", 13 "zipkin-transport-http": "^0.7.2" 14 } 15 }
安裝相關依賴
npm install
創建並編輯 app.js
請在 /data/release/service_a
目錄下創建 app.js,參考下面的內容。
示例代碼:/data/release/service_a/app.js
1 const express = require('express'); 2 const {Tracer, ExplicitContext, BatchRecorder} = require('zipkin'); 3 const {HttpLogger} = require('zipkin-transport-http'); 4 const zipkinMiddleware = require('zipkin-instrumentation-express').expressMiddleware; 5 6 const ctxImpl = new ExplicitContext(); 7 const recorder = new BatchRecorder({ 8 logger: new HttpLogger( { 9 endpoint: 'http://127.0.0.1:9411/api/v1/spans' 10 }) 11 }); 12 13 const tracer = new Tracer({ctxImpl, recorder}); 14 15 const app = express(); 16 17 app.use(zipkinMiddleware({ 18 tracer, 19 serviceName: 'service-a' 20 })); 21 22 app.use('/', (req, res, next) => { 23 res.send('hello world'); 24 }); 25 26 app.listen(3000, () => { 27 console.log('service-a listening on port 3000!') 28 });
啟動服務
node app.js
該服務監聽 3000 端口, 使用瀏覽器訪問 http://118.89.65.22:3000 后,看到“hello world” 的文本字樣說明服務已經正常工作。
部署完成
查看采集到的追蹤數據
大功告成
恭喜您已經完成了搭建基於 ZIPKIN 的數據追蹤系統的學習。