当前位置: 首页 > wzjs >正文

武汉网站推广怎么做绍兴seo公司

武汉网站推广怎么做,绍兴seo公司,观看床做视频网站,做水浒传有关的网站Spring Cloud Sleuth 是一个分布式追踪解决方案,帮助你在基于 Spring 的系统中追踪请求如何在多个微服务之间流转。它能提供关于请求流转的关联信息,有助于调试、监控以及理解微服务之间的交互。从而更容易识别瓶颈、延迟问题和故障。 Spring Cloud Sle…

Spring Cloud Sleuth 是一个分布式追踪解决方案,帮助你在基于 Spring 的系统中追踪请求如何在多个微服务之间流转。它能提供关于请求流转的关联信息,有助于调试、监控以及理解微服务之间的交互。从而更容易识别瓶颈、延迟问题和故障。

Spring Cloud Sleuth 的最后一个小版本是 3.1,它不适用于 Spring Boot 3.x 及更高版本。其核心功能已迁移到 Micrometer Tracing 项目。这里还是以spring boot 2版本演示功能。

添加依赖

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

定义应用名称:spring.application.name = sleuthTest

controller定义

@RestController
@Slf4j
public class SleuthTestController {@RequestMapping("/sleuth/test")public String test(){log.info("hello,sleuth");return "ok";}
}

然后启动springboot访问定义的接口,最后日志会输出:

2025-05-12 16:11:57.949 INFO [sleuthTest,d5e3526e52257a4b,d5e3526e52257a4b] 11192 — [io-18820-exec-4] com.cpx.controller.SleuthTestController : hello,sleuth
2025-05-12 16:11:57.950 INFO [sleuthTest,d5e3526e52257a4b,d5e3526e52257a4b] 11192 — [io-18820-exec-4] com.cpx.controller.SleuthTestController : end

这里看到sleuth往日志中加了一些东西,方括号中间部分。

[application name,traceId,spanId]

traceId(链路):一条链路代表一个请求在分布式系统中的完整流程。它有一个在处理该请求的所有服务中保持不变的唯一 ID。

spanId(跨度):一个跨度代表链路中的一个具体操作。处理请求所涉及的每个服务或组件都会创建一个或多个跨度。跨度有自己的唯一 ID

手动开启新span

正常情况下在同一个服务中,controller调用本服务内的service这个会是同一个span。但是可以通过Tracer来手动开启一个新span。

public class SleuthService {@Autowiredprivate Tracer tracer;public void test(){Span span = tracer.nextSpan().name("service").start();try(Tracer.SpanInScope ws = tracer.withSpan(span)){log.info("service do sth");}finally {span.end();}}
}

这里service.test方法会和controller的traceId相同,spanId不同。

跨服调用

首先还是假设有一个system服务,这个seluth服务调用system服务的一个接口。这两个模块都要依赖starter-naocos-discovery和starter-seluth。seluth模块还要依赖openfeign模块。依赖就不贴了,前面的文章都有提到过。这里发没发现一个问题,在开发微服务项目时候很多都需要依赖共同的一些基础包,这个时候其实可以抽出来一个common模块,用来定义公共依赖和配置,然后每个服务依赖这个模块,这样就不用在每个服务里都写一遍共同依赖了。

回到我们跨服务调用场景里来:

先看被调用服务system:

添加seluth依赖

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

nacos注册部分就不写了,定义一个接口

@RestController
public class TestController {@RequestMapping("/sys/params")public String params(){log.info("system params");return "params";}
}

这里打印一行日志就是用来观察seluth输出信息变化的

seluth服务:

添加nacos依赖,openfeign依赖用来调用system服务上面定义的接口。

启动类上添加@EnableFeignClients开启feign,然后定义一个feignclient

@FeignClient(value = "system",qualifiers = "systemClient")
public interface SystemClient {@RequestMapping("/sys/params")public String getSysParams();
}

然后在controller里调用systemClient

@Resource
private SystemClient systemClient;@RequestMapping("/sleuth/feign")
public String feign(){log.info("start");systemClient.getSysParams();log.info("end");return "ok";
}

调用接口/sleuth/feign然后观察日志:

sleuth服务:

2025-05-12 16:19:03.272 INFO [sleuthTest,dbfab2d909e6adc5,dbfab2d909e6adc5] 11192 — [o-18820-exec-10] com.cpx.controller.SleuthTestController : start
2025-05-12 16:19:03.281 INFO [sleuthTest,dbfab2d909e6adc5,dbfab2d909e6adc5] 11192 — [o-18820-exec-10] com.cpx.controller.SleuthTestController : end

system服务:

2025-05-12 16:19:03.280 INFO [system,dbfab2d909e6adc5,315a41e1974cae6f] 13212 — [io-18082-exec-4] com.cpx.TestController : system params

这里发现sleuth服务调用system服务,traceId相同,spanId变了。这样如果所有日志最后通过日志收集到一块后,就可以很容易根据traceId进行追踪调用链路。这里在调用system服务的时候,是由sleuth将traceId和spanId通过http header传递给system的。

Sleuth 自动检测并记录常见的 Spring 组件和库的操作,例如 Spring MVC、RestTemplate、Spring WebFlux、Feign 客户端、Spring Cloud Gateway 和消息中间件。无需编写任何代码即可获得基本的追踪信息。

http://www.dtcms.com/wzjs/476277.html

相关文章:

  • 网站设计制作哪些seo博客
  • 设计图片素材网站有哪些提高工作效率图片
  • 做网站咨询推广策划方案模板
  • 分析网站的关键词优化百度百科
  • 做论坛app网站有哪些作品推广
  • 建设一个视频网站需要什么网络优化工程师
  • 网站200mb空间关键词歌词打印
  • 优化网站排名怎么制作app推广方案模板
  • 官网网站建设yoast seo教程
  • 大连里程科技做网站上海关键词优化外包
  • 机构网站建设需要交费吗对网络推广的理解
  • 利用百度网盘自动播放做视频网站杭州网站推广优化公司
  • 电商网站设计图宁波seo整体优化公司
  • 国外网站做家具哪个好汕头seo优化公司
  • 成都网站制作scgckj做网站用什么软件好
  • 北京最大网站建设公司排名贺州seo
  • 长春网站制作工具百度站长资源
  • ui做的好的网站有哪些电脑培训班多少费用
  • 黄骅市做网站价格杭州排名优化公司电话
  • 贵阳网站开发seo优化的主要任务包括
  • 香港 网站 空间申请表谷歌搜索引擎营销
  • 东营做营销型网站建设公司推广策划方案
  • 网站建设wap站咸宁网站seo
  • 郑州网站建设公司服务公司舆情信息
  • 社区网站建设工作职责站长工具在线
  • 网站开发项目需求方案百度网站优化软件
  • 网站建设泉州效率网络如何给公司网站做推广
  • 国家市场监管总局官网网站放单平台大全app
  • 平阴网站建设找公司做网站多少钱
  • 做技术支持的网站有百度自动点击器怎么用