java技术--SpringCloud:服务追踪Sleuth代码实现(20)

1.主要讲述服务追踪组件zipkin,Spring Cloud Sleuth集成了zipkin组件
2.构建工程

(1)主要有三个工程组成:
   <1>ZipkinServer:它的主要作用作为链路追踪服务中心,负责存储链路数据
   <2>创建两个应用实例EurekaClient,EurekaClient1:分别对外暴露各自的接口
     2.1.这两个可以相互调用
     2.2.并且只有调用了ZipkinServer才会收集数据的
     2.3.这就是叫服务追踪了

3.构建ZipkinServer工程

(1)在spring Cloud为F版本的时候,已经不需要构建ZipkinServer了
   <1>只需要下载jar即可,下载地址:
https://dl.bintray.com/openzipkin/maven/io/zipkin/java/zipkin-server/
   <2>源码下载:
   https://github.com/forezp/SpringCloudLearning/tree/master/sc-f-chapter9
   <3>下载完成jar 包之后,需要运行jar,如下
     3.1.将下载好的jar包放入jdk中的lib文件夹下
     3.2.使用命令启动运行:java -jar zipkin-server-2.10.1-exec.jar
     3.3.在cmd窗口查找访问端口,进行浏览器访问:localhost:9411

4.改造EurekaClients

(1)在其pom引入起步依赖spring-cloud-starter-zipkin,代码示例如下
    <dependency>
		<groupId>org.springframework.cloud</groupId>
		<artifactId>spring-cloud-starter-zipkin</artifactId>
	</dependency>
(2)在配置文件application.properties指定zipkin server的地址,代码示例如下
  server.port=8001
  eureka.client.service-url.defaultZone=http://localhost:8000/eureka/
  #指定服务名,服务提供者
  spring.application.name:EurkaClient
  spring.zipkin.base-url=http://localhost:9411
(3)通过引入spring-cloud-starter-zipkin依赖和设置spring.zipkin.base-url就可以了  

5.改造EurekaClientApplication,代码示例如下:

  @SpringBootApplication
  @RestController
  public class EurekaClientApplication{
	public static void main(String[] args) {
		SpringApplication.run(ServiceHiApplication.class, args);}
	private static final Logger LOG = Logger.getLogger(ServiceHiApplication.class.getName());
	@Autowired
	private RestTemplate restTemplate;
	@Bean
	public RestTemplate getRestTemplate(){return new RestTemplate();}
	@RequestMapping("/hi")
	public String callHome(){
		LOG.log(Level.INFO, "calling trace service-hi  ");
		return restTemplate.getForObject("http://localhost:8989/miya", String.class);}
	@RequestMapping("/info")
	public String info(){
		LOG.log(Level.INFO, "calling trace service-hi ");return "i'm service-hi";}
	/**
	 * Jmeter常用控件:Sampler
	 * 1.性能测试过程中向服务器发送请求,记录响应信息,记录响应时间的最小单元
	 */	
	@Bean
	public Sampler defaultSampler() {return Sampler.ALWAYS_SAMPLE;}}

6.启动工程,演示追踪

(1)依次启动工程,打开浏览器访问:http://localhost:9411/
   <1>会出现Zipkin界面
(2)访问:http://localhost:8001/hi
(3)再打开http://localhost:9411/的界面
   <1>点击Dependencies,可以发现服务的依赖关系
   <2>点击find traces,可以看到具体服务相互调用的数据

7.参考文档

(1)源码下载:https://github.com/forezp/SpringCloudLearning/tree/master/sc-f-chapter9
(2)https://github.com/spring-cloud/spring-cloud-sleuth
(3)https://www.fangzhipeng.com/springcloud/2018/08/09/sc-f9-sleuth.html
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值