1、微服务下的链路追踪讲解和重要性
简介:讲解什么是分布式链路追踪系统,及使用好处
当系统比较慢的时候,可以追踪性能耗在哪里,哪个服务出了问题
2、SpringCloud的链路追踪组件Sleuth实战
简介:讲解分布式链路追踪组件Sleuth实战
1、官方文档
http://cloud.spring.io/spring-cloud-static/Finchley.SR1/single/spring-cloud.html#sleuth-adding-project
2、什么是Sleuth
一个组件,专门用于记录链路数据的开源组件
最主要功能:打印链路的日志(日志埋点)
在order-serviceh和product-service加入依赖
1 <dependency> 2 <groupId>org.springframework.cloud</groupId> 3 <artifactId>spring-cloud-starter-sleuth</artifactId> 4 </dependency>
启动项目访问
http://localhost:9000/apigateway/order/api/vi/order/save?product_id=2&user_id=5&token=77777
看order-service控制台
分析: [order-service,9a1334b6f2d6d3d8,e4e8364b485accd5,false]
1、第一个值,spring.application.name的值
2、第二个值,9a1334b6f2d6d3d8,sleuth生成的一个ID,叫Trace ID,用来标识一条请求链路,一条请求链路中包含一个Trace ID,多个Span ID
3、第三个值,e4e8364b485accd5、span Id 基本的工作单元,获取元数据,如发送一个http
4、第四个值:false,是否要将该信息输出到zipkin服务中来收集和展示。
3、添加依赖
3、SpringCloud的链路追踪组件Sleuth常见问题说明
简介:讲解分布式链路追踪组件Sleuth常见问题说明
当第二次访问时
http://localhost:9000/apigateway/order/api/vi/order/save?product_id=2&user_id=5&token=77777
看不到[order-service,9a1334b6f2d6d3d8,e4e8364b485accd5,false]这样的信息
在order-service服务下修改
1 package com.po.order_service.service.impl; 2 3 import com.fasterxml.jackson.databind.JsonNode; 4 import com.po.order_service.domain.ProductOrder; 5 import com.po.order_service.service.ProductClient; 6 import com.po.order_service.service.ProductOrderService; 7 import com.po.order_service.util.JsonUtil; 8 import org.slf4j.Logger; 9 import org.slf4j.LoggerFactory; 10 import org.springframework.beans.factory.annotation.Autowired; 11 import org.springframework.cloud.client.ServiceInstance; 12 import org.springframework.cloud.client.loadbalancer.LoadBalancerClient; 13 import org.springframework.stereotype.Service; 14 import org.springframework.web.client.RestTemplate; 15 16 import java.util.Date; 17 import java.util.Map; 18 import java.util.UUID; 19 20 @Service 21 public class ProductOrderServiceImpl implements ProductOrderService { 22 @Autowired 23 private ProductClient productClient; 24 25 private final Logger logger= LoggerFactory.getLogger(getClass()); 26 27 @Override 28 public ProductOrder save(int userId, int productId) { 29 logger.info("调用了save方法。。。"); 30 final String response = productClient.findById(productId); 31 //JsonNode和Map效果一致 32 JsonNode jsonNode = JsonUtil.strToJsonNode(response); 33 ProductOrder order = new ProductOrder(); 34 order.setCreateTime(new Date()); 35 order.setUserId(userId); 36 order.setTradeNo(UUID.randomUUID().toString());//订单编号 37 38 order.setProductName(jsonNode.get("name").toString()); 39 order.setPrice(Integer.parseInt(jsonNode.get("price").toString())); 40 return order; 41 } 42 }
product-service服务也修改
1 package com.po.product_service.service.impl; 2 3 import com.po.product_service.domain.Product; 4 import com.po.product_service.service.ProductService; 5 import org.slf4j.Logger; 6 import org.slf4j.LoggerFactory; 7 import org.springframework.stereotype.Service; 8 9 import java.util.*; 10 11 @Service 12 public class ProductServiceImpl implements ProductService { 13 //日志打印 14 private final Logger logger= LoggerFactory.getLogger(getClass()); 15 private static final Map<Integer,Product> map =new HashMap<Integer,Product>(); 16 static { 17 Product p1 = new Product(1, "iPhone8", 8999, 10); 18 Product p2 = new Product(2, "iPhone7", 7999, 20); 19 Product p3 = new Product(3, "iPhone6", 6999, 30); 20 Product p4 = new Product(4, "iPhone4", 5999, 50); 21 Product p5 = new Product(5, "iPhone5", 999, 10); 22 Product p6 = new Product(6, "iPhoneX", 9999, 60); 23 map.put(p1.getId(),p1); 24 map.put(p2.getId(),p2); 25 map.put(p3.getId(),p3); 26 map.put(p4.getId(),p4); 27 map.put(p5.getId(),p5); 28 map.put(p6.getId(),p6); 29 } 30 @Override 31 public List<Product> listProduct() { 32 Collection<Product> po = map.values(); 33 List<Product> list = new ArrayList<>(po); 34 return list; 35 } 36 37 @Override 38 public Product findProduct(int id) { 39 logger.info("通过id查找产品。。。"); 40 return map.get(id); 41 } 42 }
先启动product-service 在启动order-service最后一定要启动api-gedaway网关服务
现在每一次访问http://localhost:9000/apigateway/order/api/vi/order/save?product_id=2&user_id=5&token=77777
两个服务都有
order-service服务控制台
[order-service,14ae768391eb0b5c,8069c56eaf2ac0b7,false]
product-service服务控制台
[product-service,14ae768391eb0b5c,d97ad99a7124ae49,false]
证明:一条请求链路中包含一个Trace ID,多个Span ID
4、可视化链路追踪系统Zipkin部署
简介:讲解Zipkin的介绍和部署
1、什么是zipkin
官网:https://zipkin.io/
大规模分布式系统的APM工具(Application Performance Management),基于Google Dapper的基础实现,和sleuth结合可以提供可视化web界面分析调用链路耗时情况
APM就是英文Action Per Minute的首字母缩写,意为每分钟的活动次数,要软件测试才能看出来你的APM是多少
2、同类产品
鹰眼(EagleEye)
CAT
twitter开源zipkin,结合sleuth
Pinpoint,运用JavaAgent字节码增强技术
StackDriver Trace (Google)
3、开始使用
https://github.com/openzipkin/zipkin
https://zipkin.io/pages/quickstart.html
zipkin组成:Collector(控制器)、Storage(存储)、Restful API(API外部可以使用)、Web UI(看到的界面)组成
zipkin server就是一个jar包
下载下来
用docker方式docker run -d -p 9411:9411 openzipkin/zipkin
4、知识拓展:OpenTracing
OpenTracing 已进入 CNCF,正在为全球的分布式追踪,提供统一的概念和数据标准。
通过提供平台无关、厂商无关的 API,使得开发人员能够方便的添加(或更换)追踪系统的实现。
推荐阅读:
http://blog.daocloud.io/cncf-3/
https://www.zhihu.com/question/27994350
https://yq.aliyun.com/articles/514488?utm_content=m_43347
5、高级篇幅之链路追踪组件Zipkin+Sleuth实战
简介:使用Zipkin+Sleuth业务分析调用链路分析实战
1、文档
http://cloud.spring.io/spring-cloud-static/Finchley.SR1/single/spring-cloud.html#_sleuth_with_zipkin_via_http
sleuth收集跟踪信息通过http请求发送给zipkin server,zipkinserver进行跟踪信息的存储以及提供Rest API即可,Zipkin UI调用其API接口进行数据展示
默认存储是内存,可也用mysql、或者elasticsearch等存储
2、加入依赖
1 <dependency> 2 <groupId>org.springframework.cloud</groupId> 3 <artifactId>spring-cloud-starter-zipkin</artifactId> 4 </dependency>
里面包含 spring-cloud-starter-sleuth、spring-cloud-sleuth-zipkin
3、文档说明:http://cloud.spring.io/spring-cloud-static/Finchley.SR1/single/spring-cloud.html#_features_2
4、配置zipkin.base-url
5、配置采样百分闭spring.sleuth.sampler
推荐资料:
https://blog.csdn.net/jrn1012/article/details/77837710