最近在搞微服务的组件搭建,本来使用的是spring-boot+spring-cloud搭建采用的链路追踪方案为
sleuth+zipkin,由于之前搞过spring-cloud的dalston的版本,当时还是支持zipkin的版本的,可以直接引用极简单的组件就可以搭建zipkin-server,最近在用最新版本的spring-boot 2.7.0版本进行搭建过程中发现问题重重,主要是zipkin不知道从什么时候在spring cloud官方网站上剔除了,找了好多资料也没有个头绪,最后,自己探索了一下,以下为探索过程的记录
先说一下结论,当前的zipkin-server是可以自己到官网下载已有的独立jar包,或者是docker镜像进行安装使用的,如果有对zipkin有特殊定制化要求的,或者是想自己搭建一下的可以参考下面步骤。目前遇到的主要问题是,当前的zipkin-server在maven的仓库里发布的最新版本为2.12.9,而且看似从2019年开始并未再进行过发版了。所以对于当前的spring boot的最新版本无法兼容。如果想要自己搭建,需要引用单独兼容版本的spring boot版本就可以了。
新建独立工程zipkin-server-test
修改pom文件,添加zipkin-server的2.12.X版本支持的spring boot版本,这里说一下为什么pom中的版本是2.12.3而不是上面说的2.12.9,这里面有一个小坑,是由于官方新加入的组件有不兼容问题,所以需要使用低版本,由于后面官方未能发布新版本,所有此bug一直存在。
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/maven-v4_0_0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>com.jack.test</groupId>
<artifactId>micro-zipkin-server-test</artifactId>
<packaging>jar</packaging>
<version>1.0</version>
<name>micro-zipkin-server-test</name>
<url>http://maven.apache.org</url>
<properties>
<zipkin.server.version>2.12.3</zipkin.server.version>
</properties>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-dependencies</artifactId>
<version>2.1.4.RELEASE</version>
<scope>import</scope>
<type>pom</type>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>io.zipkin.java</groupId>
<artifactId>zipkin-server</artifactId>
<version>${zipkin.server.version}</version>
</dependency>
<dependency>
<groupId>io.zipkin.java</groupId>
<artifactId>zipkin-autoconfigure-ui</artifactId>
<version>${zipkin.server.version}</version>
</dependency>
<dependency>
<groupId>org.projectlombok</groupId>
<artifactId>lombok</artifactId>
</dependency>
</dependencies>
</project>
修改application.yml
server:
port: 9090
spring:
application:
name: zipkin-test-server
main:
allow-bean-definition-overriding: true
management:
metrics:
web:
server:
auto-time-requests: false
修改启动入口这里的@EnableZipkinServer主要要引用zipkin2.server.internal.EnableZipkinServer包下的
@EnableZipkinServer
@SpringBootApplication
public class ZipkinServerTestApplication
{
public static void main( String[] args )
{
SpringApplication.run(ZipkinServerTestApplication.class,args);
}
}
按照以上步骤就可以完成项目的搭建启动也是可以访问的