微服务Sleuth解析部署使用全流程

目录

1、Sleuth链路追踪

1、添加依赖

2、修改日志配置文件

3、测试

2、zipkin可视化界面

1、docker安装

2、添加依赖

3、修改配置文件

4、查看页面

5、ribbon配置


1、Sleuth链路追踪

sleuth是链路追踪框架,用于在微服务架构下开发,各个微服务之间通信,很难查询日志,也不容易判断问题出现在哪里,通过sleuth可以将整个微服务通信的链路连接起来查看,方便开发定位问题。

https://docs.spring.io/spring-cloud-sleuth/docs/2.2.5.RELEASE/reference/html/

本文章使用 OpenFeign的项目(详细请看本链接)

微服务 OpenFeign 解析部署使用全流程_微服务a 的token通过openfeign 传递到b服务 服务b如何使用-CSDN博客

1、添加依赖

两个工程都添加:

复制代码
<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-starter-sleuth</artifactId>
</dependency>

2、修改日志配置文件

修改application.yml配置文件,

复制代码
logging:
  level:
    org:
      springframework:
        cloud:
          openfeign: debug
          sleuth: debug

3、测试

访问接口输出上图日志,代表sleuth添加成功。

2、zipkin可视化界面

是一个可视化工具,支持sleuth展示。是推特公司出品。

1、docker安装

复制代码
#命令1:
docker pull openzipkin/zipkin
#命令2:
docker run --name zipkin -d -p 9411:9411 openzipkin/zipkin

2、添加依赖

两个工程都添加依赖:

复制代码
<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-zipkin</artifactId>
</dependency>

3、修改配置文件

application.yml配置文件,添加如下配置:

ip地址换成自己的

复制代码
spring:
  zipkin:
    base-url: http://192.168.17.128:9411
    discovery-client-enabled: false
    sender:
      type: web
  sleuth:
    sampler:
      probability: 1
    opentracing:
      enabled: false

4、查看页面

http://192.168.17.128:9411/

ip加虚拟机端口号

可以明显看出第一次请求耗时较长,因为数据库连接采用懒加载方式,第一次请求会创建数据库连接,后续就直接使用了。

5、ribbon配置

复制代码
ribbon:
  ReadTimeout: 120000
  ConnectTimeout: 30000

解决feign接口调用时debug导致的超时问题。

使用场景:

user工程访问Score工程的时候,Score工程设置一个断点,同时开启Bebug模式,由于断点的原因需要停顿,user工程的请求会超时。

使用ribbon设置就可以。

相关推荐
你不是我我8 小时前
【Java 开发日记】HTTP3 性能更好,为什么内网微服务依然多用 HTTP2?HTTP2 内网优势是什么?
java·开发语言·微服务
雪碧聊技术8 小时前
大模型爆火!Java后端如何抓住Agent全栈开发的风口
java·大模型·agent·全栈开发
Filwaod8 小时前
互联网大厂Java面试实战:Spring Boot微服务架构与AI技术栈深度解析
spring boot·微服务·大厂面试·java面试·技术干货·ai技术栈·程序员求职
逻辑驱动的ken10 小时前
Java高频面试场景题25
java·开发语言·深度学习·面试·职场和发展
飞Link10 小时前
OpenAI 与微软“非排他性”协议解读:AI 云计算市场将迎来百家争鸣?
人工智能·microsoft·云计算
AI人工智能+电脑小能手10 小时前
【大白话说Java面试题】【Java基础篇】第32题:Java的异常处理机制是什么
java·开发语言·后端·面试
爱吃土豆的马铃薯ㅤㅤㅤㅤㅤㅤㅤㅤㅤ12 小时前
通过java后端代码来实现给word内容补充格式文本内容控件,以及 设置控件的标记和标题
java·c#·word
無限進步D12 小时前
Java 面向对象高级 接口
java·开发语言
逸Y 仙X13 小时前
文章二十七:ElasticSearch ES查询模板(Search Template)高效复用实战
java·大数据·数据库·elasticsearch·搜索引擎·全文检索