Spring Cloud Sleuth

2017-10-20  本文已影响0人  踏雪寻梅4149

分布式服务追踪Sleuth, Zipkin

基本概念

Distributed tracing for Spring Cloud applications, compatiblewith Zipkin, HTrace and log-based(e.g. ELK)tracing
http://cloud.spring.io/spring-cloud-static/Dalston.SR4/single/spring-cloud.html#_spring_cloud_sleuth
http://m.blog.csdn.net/forezp/article/details/76795269
http://blog.csdn.net/forezp/article/details/70162074

安装使用:

mysql存储, HTTP同步发送

服务端:

  1. pom 添加依赖
<!-- Zipkin server 相关依赖 -->
        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-server</artifactId>
        </dependency>
        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-autoconfigure-ui</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-autoconfigure-storage-mysql</artifactId>
        </dependency>
          
  1. application.properties 添加配置
  # Database data source
  zipkin.storage.type=mysql
  spring.datasource.url=jdbc:mysql://localhost:3306/zipkin?useUnicode=true&characterEncoding=utf-8&useSSL=false&autoReconnect=true
  spring.datasource.username=root
  spring.datasource.password=123456
  spring.datasource.driver-class-name=com.mysql.jdbc.Driver
  
  # 服务发现服务注册中心配置
  server.port=9411
  spring.application.name=zipkin-server
  eureka.client.serviceUrl.defaultZone=http://ip1:9001/eureka/,http://ip2:9001/eureka/   
  

客户端:

  1. pom 添加依赖
<!-- zipkin 追踪服务 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-zipkin</artifactId>
    </dependency>
  1. 添加配置

spring.zipkin.service.name=hello1 //可以修改当前监控的服务在zipkin端的显示名
spring.zipkin.base-url=http://localhost:9411 //zipkin-server的ip和端口
spring.sleuth.sampler.percentage=0.8 //抽样比例,1是全部抽样。 默认0.1
spring.zipkin.locator.discovery.enabled=true //是否显示ip

如果正常的话:你的log将会如下
**注意通用的调用并不是每次都会收集到zipkin server,由抽样比例决定。
在客户端[bootstrap,f58419e2ceb834b9,f58419e2ceb834b9,true] 为[appname,traceId,spanId,exportable]
最后一个boolean表示是否收集到zipkin。第二位为traceid

2017-10-12 13:55:15.251 DEBUG [bootstrap,f58419e2ceb834b9,f58419e2ceb834b9,true] 45689 --- [nio-8021-exec-4] o.s.web.servlet.DispatcherServlet        : Null ModelAndView returned to DispatcherServlet with name 'dispatcherServlet': assuming HandlerAdapter completed request handling
2017-10-12 13:55:15.251 DEBUG [bootstrap,f58419e2ceb834b9,f58419e2ceb834b9,true] 45689 --- [nio-8021-exec-4] o.s.web.servlet.DispatcherServlet        : Successfully completed request
2017-10-12 13:55:15.489 DEBUG [bootstrap,06e01f462feb666e,06e01f462feb666e,false] 45689 --- [nio-8021-exec-5] o.s.web.servlet.DispatcherServlet        : DispatcherServlet with name 'dispatcherServlet' processing GET request for [/health]

发现问题:

Kafka存储和异步发送

服务端配置

  1. pom 依赖添加
<!-- Zipkin server 相关依赖 -->
        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-server</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-stream-kafka</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-sleuth-zipkin-stream</artifactId>
        </dependency>
  1. 配置添加
spring.cloud.stream.kafka.binder.brokers=localhost:9092
spring.could.stream.kafka.binder.zkNodes=localhost:2181
  1. Annotation
    由//@EnableZipkinServer 改为 @EnableZipkinStreamServer

客户的配置

  1. POM 添加
<!-- zipkin 追踪服务 -->
   <!-- <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-zipkin</artifactId>
    </dependency> -->


    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-stream-kafka</artifactId>
    </dependency>

    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-sleuth-zipkin-stream</artifactId>
    </dependency>
  1. 配置添加
spring.zipkin.service.name=hello2
#spring.zipkin.base-url=http://localhost:9411
spring.sleuth.sampler.percentage=0.8
spring.zipkin.locator.discovery.enabled=true

spring.cloud.stream.kafka.binder.brokers=localhost:9092
#172.23.75.35:
#spring.could.stream.kafka.binder.zkNodes=172.23.75.47:2181,172.23.75.48:2181,172.23.75.49:2181
spring.could.stream.kafka.binder.zkNodes=localhost:2181

ELK

http://m.blog.csdn.net/forezp/article/details/76795269
ELK安装:此处略过安装过程
配置:

  1. zipkin server:
 <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin</artifactId>
            <version>1.28.0</version>
        </dependency>
        <dependency>
            <groupId>io.zipkin.java</groupId>
            <artifactId>zipkin-autoconfigure-storage-elasticsearch-http</artifactId>
            <version>1.28.0</version>
        </dependency>     

同时注意删除mysql相关依赖

  1. 配置文件:
zipkin.storage.type=elasticsearch
zipkin.storage.elasticsearch.hosts=localhost:9200
zipkin.storage.elasticsearch.cluster=elasticsearch
zipkin.storage.elasticsearch.index=zipkin
zipkin.storage.elasticsearch.index-shards=5
zipkin.storage.elasticsearch.index-replicas=1

HTrace

Zipkin

分布式tracing系统论文鼻祖:https://research.google.com/pubs/pub36356.html
源码: https://github.com/openzipkin/zipkin/wiki
官网文档: http://zipkin.io/
背景和设计:
http://cloud.spring.io/spring-cloud-static/Dalston.SR4/single/spring-cloud.html#_spring_cloud_sleuth

目标

code tracing: 需要抽取有用信息
debuging exception:
performance and profiling:
做关键点的trace;

上一篇 下一篇

猜你喜欢

热点阅读