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