SpringCloud--Zipkin链路跟踪(十四)

一、Zipkin简介

  Zipkin是SpringCloud官方推荐的一款分布式链路监控的组件,使用它我们可以得知每一个请求所经过的节点以及耗时等信息,并且它对代码无任何侵入。Zipkin是 Twitter 的一个 开源项目 ,它基于 Google Dapper实现。我们可以使用它来收集各个 服务器 上请求链路的跟踪数据,并通过它提供的 REST API 接口来辅助我们查询跟踪数据以实现对分布式系统的监控程序,从而及时地发现系统中出现的延迟升高问题并找出系统性能瓶颈的根源。除了面向 开发 的API接口之外,它也提供了方便的 UI 组件来帮助我们直观的搜索跟踪信息和分析请求链路明细,比如:可以查询某段时间内各用户请求的处理时间等。


Zipkin的基础架构

Zipkin的基础架构,它主要有4个核心组件构成:

  1. Collector:收集器组件,它主要用于处理从外部系统发送过来的跟踪信息,将这些信息转换为Zipkin内部处理的Span格式,以支持后续的存储、分析、展示等功能。
  2. Storage:存储组件,它主要对处理收集器接收到的跟踪信息,默认会将这些信息存储在内存中,我们也可以修改此存储策略,通过使用其他存储组件将跟踪信息存储到 数据库 中。
  3. RESTful API:API组件,它主要用来提供外部访问接口。比如给客户端展示跟踪信息,或是外接系统访问以实现监控等。
  4. Web UI:UI组件,基于API组件实现的上层应用。通过UI组件用户可以方便而有直观地查询和分析跟踪信息。

示例结构图:


Zipkin链路跟踪

① 工程下有4个模块:一个注册中心,一个 Zipkin 服务以及两个提供者
② Zipkin 也分为两部分,server 端和 client 端
③ server 端:收集数据,并展示
④ client 端:把调用信息发送给 server 端

二、Maven依赖

  1. 服务端Maven依赖
<!--zipkin-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-zipkin</artifactId>
</dependency>
<!--图形界面-->
<dependency>
    <groupId>io.zipkin.java</groupId>
    <artifactId>zipkin-autoconfigure-ui</artifactId>
    <version>2.11.8</version>
</dependency>
<dependency>
    <groupId>io.zipkin.java</groupId>
    <artifactId>zipkin-server</artifactId>
    <version>2.11.8</version>
    <exclusions>
        <exclusion>
            <groupId>org.apache.logging.log4j</groupId>
            <artifactId>log4j-slf4j-impl</artifactId>
        </exclusion>
    </exclusions>
</dependency>

注意:zipkin的版本问题,在此使用的为2.11.8,其它版本报不同错误。

  1. Zipkin客户端Maven配置
<!--zipkin-->
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-zipkin</artifactId>
    <version>2.1.3.RELEASE</version>
</dependency>

三、配置

  1. 服务端 application.properties 配置
server.port=9411
# zipkin 配置
# 采集率
spring.sleuth.sampler.probability=1.0
# 是否启动zipkin,默认为true
spring.zipkin.enabled=true
# 支持通过服务发现来定位host name:
spring.zipkin.locator.discovery.enabled=true
# 是否启动zipkin地址
spring.zipkin.base-url= http://localhost:9411
#zipkin启动报错无法访问的解决方法 设置为false,默认为true; 关闭自动配置启用所有请求得检测
management.metrics.web.server.auto-time-requests=false

  1. 服务端启动类
    添加注解:@EnableZipkinServer
@SpringBootApplication
@EnableZipkinServer
public class SpringZipkinApplication {
    public static void main(String[] args) {
        SpringApplication.run(SpringZipkinApplication.class, args);
    }
}
  1. 客户端application.properties 配置
# zipkin服务器地址
spring.zipkin.baseUrl=http://localhost:9411/
# 即100%的概率将链路的数据上传给Zipkin Server,在默认的情况下,该值为0.1
spring.sleuth.sampler.probability=1.0
# 过滤掉URL
spring.sleuth.web.skipPattern=(^cleanup.*)

  1. 客户端服务提供
spring.application.name=user-client

# 控制器服务提供代码
@RestController
@RequestMapping("user")
public class UserController {
    @GetMapping
    public String getUser() {
        return "admin";
    }
}
  1. 客户端服务消费
spring.application.name=goods-client
# 控制器服务消费代码
@RestController
@RequestMapping("goods")
public class GoodsController {
    @Autowired
    private RestTemplate restTemplate;

    /**
     * 注入Rest模板
     * @return
     */
    @Bean
    public RestTemplate getRestTemplate() {
        return new RestTemplate();
    }
    @GetMapping
    public String getGoodsByUser() {
        String response = (String) restTemplate.exchange("http://localhost:8080/user",
                HttpMethod.GET, null, new ParameterizedTypeReference<String>() {
                }).getBody();
        return  response;
    }
}

四、测试

  1. zipkin服务端监控
    http://localhost:9411/zipkin/

    服务

  2. 服务调用
    http://localhost:8081/goods

    服务调用

  3. 链路查看

    链路查看

    ![链路查看

五、常见错误

  1. Spring Boot2.1.7启动zipkin-server报错:Error creating bean with name 'armeriaServer' defined in class path
    Zipkin最新2.12.9版从2.12.6开始有个较大的更新,迁移使用了Armeria HTTP引擎。存在版本冲突。
    使用:

  1. Caused by: java.lang.ClassNotFoundException: com.linecorp.armeria.common.HttpHeaders
    zipkin-server的maven版本与spring-boot-starter-parent的maven版本不一致导致。

  2. Prometheus requires that all meters with the same name have the same set of tag keys.
    在application.properties中添加配置:

# zipkin启动报错无法访问的解决方法
management.metrics.web.server.auto-time-requests=false
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343

推荐阅读更多精彩内容