[关闭]
@kklinan 2019-03-05T06:21:44.000000Z 字数 5867 阅读 2144

使用 Jaeger 进行服务调用链路追踪

Jaeger OpenTraing Golang 分布式跟踪


Jaeger 介绍

Jaeger (ˈyā-gər) 是 Uber 根据 Dapper 和 OpenZipkin 启发使用 Go 开发并开源且兼容 OpenTracing 的一个支持多种存储方式(Memory、Cassandra、Elasticsearch、Kafka)的端到端的由 CNCF 托管的分布式追踪项目,
包括:
- 分布式上下文
- 分布式事务监控
- 服务问题分析
- 服务依赖分析
- 性能监控

OpenTracing 介绍

OpenTracing 是一套分布式跟踪系统更佳标准化的 API 和工具,同样在 CNCF 中孵化。
支持的语言:
- Go
- C++
- C#
- Java
- Javascript
- Objective-C
- PHP
- Python
- Ruby

以下几个名词简单了解下:

Tracer

调用链: 由多个 Span 构成有向无环图。

Span

跨度:一个具有完整生命周期的程序访问,比如一次方法调用。
在 SpanContext 中的各个 Span 存在 ChildOf 和 FollowsFrom 的关系。

Tag

标签: k-v 形式的 Span 注释且key 必须是字符串。

Baggage

行李: k-v 形式 Span 间随行/传播的数据,且key、value都是字符串。

Log

日志: 一个/多个 k-v 形式数据,且key 必须是字符串。

有些 OpenTracing 的实现可以处理更多的日志的值

Cassandra 介绍

Cassandra 由 Facebook 使用 Java 开发且在2008年开源的分布式 NoSQL 数据库,2009年由 Apache 孵化托管。

使用类似 SQL 的 CQL 语言实现数据模型的定义和读写。
且与 Dynamo 系统架构类似,是基于一致性哈希的完全 P2P 架构,每行数据通过哈希来决定应该存在哪个或哪些节点中。集群没有 master 的概念,所有节点都是同样的角色,避免了单点问题,提高了稳定性。
使用了 Google 设计的 BigTable 的数据模型,与面向行(row)的传统的关系型数据库或键值存储的key-value数据库不同,Cassandra使用的是宽列存储模型(Wide Column Stores),每行数据由 row key 唯一标识之后,可以有最多20亿个列,每个列有一个column key标识,每个column key下对应若干value。这种模型可以理解为是一个二维的 key-value 存储,即整个数据模型被定义成一个类似map>的类型。

cqlsh

cqlsh 是一个命令行 shell,用于通过 CQL 与 Cassandra 交互。它随每个 Cassandra 软件包一起提供,可以在 cassandra 可执行文件旁边的 bin 目录中找到。它连接到命令行上指定的单个节点。

keyspaces

key 空间: 类似 MySQL 中的数据库。

查看所有 keyspaces

DESCRIBE KEYSPACES;

文档: https://cassandra.apache.org/doc/latest/tools/cqlsh.html#describe

创建 keyspace

  1. -- test
  2. CREATE KEYSPACE qschou
  3. WITH replication = {'class': 'SimpleStrategy', 'replication_factor' : 3};
  4. -- prod
  5. CREATE KEYSPACE qschou
  6. WITH replication = {'class': 'NetworkTopologyStrategy', 'DC1' : 1, 'DC2' : 3}
  7. AND durable_writes = false;

文档: https://cassandra.apache.org/doc/latest/cql/ddl.html#create-keyspace

选择 keyspace

USE keyspace_name

创建 table

  1. CREATE TABLE timeline (
  2. userid uuid,
  3. posted_month int,
  4. posted_time uuid,
  5. body text,
  6. posted_by text,
  7. PRIMARY KEY (userid, posted_month, posted_time)
  8. ) WITH compaction = { 'class' : 'LeveledCompactionStrategy' };

文档: https://cassandra.apache.org/doc/latest/cql/ddl.html#create-table

展示 keyspace 下所有 table

DESCRIBE qschou;

Elasticsearch 介绍

Elasticsearch 是一个高度可扩展的基于 Lucene 的开源全文搜索和分析引擎。它允许您快速,近实时地存储,搜索和分析大量数据。它通常用作底层引擎/技术,为具有复杂搜索功能和要求的应用程序提供 RESTful 接口支持。

近实时 意味着从索引文档到可搜索文档的时间有一点延迟(通常是一秒)。

Index

索引: 是具有某些类似特征的文档集合,索引由名称标识必须全部为小写。

Jaeger 快速体验

官网下载地址 https://www.jaegertracing.io/download/

GitHub 下载地址 https://github.com/jaegertracing/jaeger/releases

下载二进制文件压缩包后,运行解压后的 all-in-one 文件即可。

jaeger-all-in-one 采用内存存储数据,专为快速本地测试设计。

example-hotrod 为示例应用程序,运行访问,在 Jaeger UI 上即可查询数据。

Jaeger 组件

agent

jaeger-agent 是跟随集成 jaeger 的应用程序一起部署在每台服务器上的采集程序二进制文件。

collector

jaeger-collector 是与 agent 对接的程序文件,并将 agent 采集的数据存储在 Cassandra 或 Elasticsearch 中。可以负载均衡方式多实例运行。

query

jaeger-query 是 web-ui 层,展示和查询 Cassandra 或 Elasticsearch 中的数据。可以负载均衡方式多实例运行。

ingester

jaeger-ingester 是从 Kafka 中消费数据存储到 Cassandra 或 Elasticsearch 的服务程序。

部署

Cassandra

安装

配置文件:cassandra.yaml

docker 镜像地址

单机版

  1. docker run --name jaeger-cassandra -d -p 7000:7000 -p 7001:7001 -p 7199:7199 -p 9042:9042 -p 9160:9160 cassandra:latest

集群版

请参考文档

无论是否使用容器,单机还是集群请阅读配置文件和官方文档这里不再祥述。

创建 keyspace

  1. CREATE KEYSPACE qschou
  2. WITH replication = {'class': 'SimpleStrategy', 'replication_factor' : 3};

创建数据表

表结构地址:https://github.com/jaegertracing/jaeger/tree/master/plugin/storage/cassandra/schema

选择 v001.cql.tmplv002.cql.tmpl
注意里面有4个变量,也可以替换后在 cqlsh 中执行。

以上参数可通过 https://cassandra.apache.org/doc/latest/cql/ddl.html#create-table 查询.

Elasticsearch

安装

docker 镜像地址

单机版

  1. docker run -d --name jaeger-es -p 9200:9200 -p 9300:9300 -e "discovery.type=single-node" elasticsearch:latest

创建 index

  1. curl -X PUT \
  2. http://localhost:9200/qschou \
  3. -H 'Content-Type: application/json' \
  4. -d '{
  5. "settings" : {
  6. "index" : {
  7. "number_of_shards" : 3,
  8. "number_of_replicas" : 2
  9. }
  10. }
  11. }'

查询 index

  1. curl -X GET 'http://localhost:9200/_cat/indices?v=&='

部署 Jaeger 组件

采用 cassandra 存储

  1. # jaeger-collector
  2. SPAN_STORAGE_TYPE=cassandra ./jaeger-collector --cassandra.keyspace=qschou --cassandra.servers=127.0.0.1 --cassandra.port=9042
  3. # jaeger-query
  4. SPAN_STORAGE_TYPE=cassandra ./jaeger-query --cassandra.keyspace=qschou --cassandra.servers=127.0.0.1 --cassandra.port=9042
  5. # jaeger-agent
  6. ./jaeger-agent --collector.host-port=127.0.0.1:14267

采用 elasticsearch 存储

  1. # jaeger-collector
  2. SPAN_STORAGE_TYPE=elasticsearch ./jaeger-collector --es.server-urls=http://127.0.0.1:9200 --es.index-prefix=qschou
  3. # jaeger-query
  4. SPAN_STORAGE_TYPE=elasticsearch ./jaeger-query --es.server-urls=http://127.0.0.1:9200 --es.index-prefix=qschou
  5. # jaeger-agent
  6. ./jaeger-agent --collector.host-port=127.0.0.1:14267

Web UI 地址: http://localhost:16686

通过阿里云 sls 存储链路信息

sls 是我司常用的日志服务,可以通过 Jaeger on Aliyun Log service 进行集成。

sls endpoint https://help.aliyun.com/document_detail/29008.html

  1. # collector
  2. # 推荐部署多实例
  3. # 内网环境下请使用内网 endpoint
  4. SPAN_STORAGE_TYPE=aliyun-log ./collector-darwin --cc.endpoint=cn-hangzhou.log.aliyuncs.com --aliyun-log.access-key-id=LT** --aliyun-log.access-key-secret=ho** --aliyun-log.project=dbj-mp --aliyun-log.span-logstore=coupon-api
  5. # agent
  6. SPAN_STORAGE_TYPE=aliyun-log ./agent-darwin --collector.host-port=127.0.0.1:14267
  7. # query
  8. # 推荐部署多实例
  9. # 这里使用 docker
  10. docker run -d --name jaeger-query -p 16686:16686 -e SPAN_STORAGE_TYPE=aliyun-log registry.cn-hangzhou.aliyuncs.com/jaegertracing/jaeger-query:0.1.9 /go/bin/query-linux --aliyun-log.endpoint=cn-hangzhou.log.aliyuncs.com --aliyun-log.access-key-id=LT** --aliyun-log.access-key-secret=ho** --aliyun-log.project=dbj-mp --aliyun-log.span-logstore=coupon-api --query.static-files=/go/jaeger-ui/

相关资料

Jaeger 介绍 https://www.jaegertracing.io/docs/1.10/

Uber 分布式追踪发展历程 https://eng.uber.com/distributed-tracing/

OpenTracing 文档 https://opentracing.io/docs/translations/

Cassandra 文档 https://cassandra.apache.org/doc/latest/getting_started/index.html

Elasticsearch 接口文档 https://www.elastic.co/guide/en/elasticsearch/reference/6.6/indices-create-index.html

Jaeger 部署文档 https://www.jaegertracing.io/docs/1.10/deployment/

Opentracing Example

添加新批注
在作者公开此批注前,只有你和作者可见。
回复批注