Spring cloud sleuth 没有与 Zipkin 一起运行

     2023-02-26     148

关键词:

【中文标题】Spring cloud sleuth 没有与 Zipkin 一起运行【英文标题】:Spring cloud sleuth did not run with Zipkin 【发布时间】:2019-02-01 09:50:49 【问题描述】:

首先我对这门课有一个小问题brave.sampler.Sampler

无法导入此类,仅在我添加此依赖项时导入

   <dependency>
        <groupId>io.zipkin.brave</groupId>
        <artifactId>brave</artifactId>
        <version>4.0.5</version>
    </dependency>  

我的大问题是,当我尝试使用 zipkin 进行干扰跟踪时,我添加了所需的依赖项,但每当我启动应用程序时,它都会通过启动中的异常来实现。

这是堆栈跟踪。

java.lang.IllegalStateException: Failed to introspect Class [org.springframework.cloud.sleuth.zipkin2.sender.ZipkinRabbitSenderConfiguration] from ClassLoader [sun.misc.Launcher$AppClassLoader@764c12b6]
    at org.springframework.util.ReflectionUtils.getDeclaredMethods(ReflectionUtils.java:659) ~[spring-core-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.util.ReflectionUtils.doWithMethods(ReflectionUtils.java:556) ~[spring-core-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.util.ReflectionUtils.doWithMethods(ReflectionUtils.java:541) ~[spring-core-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.util.ReflectionUtils.getUniqueDeclaredMethods(ReflectionUtils.java:599) ~[spring-core-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.getTypeForFactoryMethod(AbstractAutowireCapableBeanFactory.java:718) ~[spring-beans-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.determineTargetType(AbstractAutowireCapableBeanFactory.java:659) ~[spring-beans-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.beans.factory.support.AbstractAutowireCapableBeanFactory.predictBeanType(AbstractAutowireCapableBeanFactory.java:627) ~[spring-beans-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.beans.factory.support.AbstractBeanFactory.isFactoryBean(AbstractBeanFactory.java:1489) ~[spring-beans-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.doGetBeanNamesForType(DefaultListableBeanFactory.java:419) ~[spring-beans-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeanNamesForType(DefaultListableBeanFactory.java:389) ~[spring-beans-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeansOfType(DefaultListableBeanFactory.java:510) ~[spring-beans-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.beans.factory.support.DefaultListableBeanFactory.getBeansOfType(DefaultListableBeanFactory.java:502) ~[spring-beans-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.context.support.AbstractApplicationContext.getBeansOfType(AbstractApplicationContext.java:1198) ~[spring-context-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    at org.springframework.boot.SpringApplication.getExitCodeFromMappedException(SpringApplication.java:892) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
    at org.springframework.boot.SpringApplication.getExitCodeFromException(SpringApplication.java:878) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
    at org.springframework.boot.SpringApplication.handleExitCode(SpringApplication.java:864) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
    at org.springframework.boot.SpringApplication.handleRunFailure(SpringApplication.java:813) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:341) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1258) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
    at org.springframework.boot.SpringApplication.run(SpringApplication.java:1246) [spring-boot-2.0.4.RELEASE.jar:2.0.4.RELEASE]
    at com.tutoriel.microservices.CurrencyExchangeServiceApplication.main(CurrencyExchangeServiceApplication.java:15) [classes/:na]
    at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) ~[na:1.8.0_181]
    at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:62) ~[na:1.8.0_181]
    at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:43) ~[na:1.8.0_181]
    at java.lang.reflect.Method.invoke(Method.java:498) ~[na:1.8.0_181]
    at org.springframework.boot.devtools.restart.RestartLauncher.run(RestartLauncher.java:49) [spring-boot-devtools-2.0.4.RELEASE.jar:2.0.4.RELEASE]
Caused by: java.lang.NoClassDefFoundError: zipkin2/reporter/Sender
    at java.lang.Class.getDeclaredMethods0(Native Method) ~[na:1.8.0_181]
    at java.lang.Class.privateGetDeclaredMethods(Class.java:2701) ~[na:1.8.0_181]
    at java.lang.Class.getDeclaredMethods(Class.java:1975) ~[na:1.8.0_181]
    at org.springframework.util.ReflectionUtils.getDeclaredMethods(ReflectionUtils.java:641) ~[spring-core-5.0.8.RELEASE.jar:5.0.8.RELEASE]
    ... 25 common frames omitted
Caused by: java.lang.ClassNotFoundException: zipkin2.reporter.Sender
    at java.net.URLClassLoader.findClass(URLClassLoader.java:381) ~[na:1.8.0_181]
    at java.lang.ClassLoader.loadClass(ClassLoader.java:424) ~[na:1.8.0_181]
    at sun.misc.Launcher$AppClassLoader.loadClass(Launcher.java:349) ~[na:1.8.0_181]
    at java.lang.ClassLoader.loadClass(ClassLoader.java:357) ~[na:1.8.0_181]
    ... 29 common frames omitted

我的 pom.xml

<?xml version="1.0" encoding="UTF-8"?>
<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/xsd/maven-4.0.0.xsd">
    <modelVersion>4.0.0</modelVersion>

    <groupId>com.example.microservices</groupId>
    <artifactId>user-service</artifactId>
    <version>0.0.1</version>
    <packaging>jar</packaging>

    <name>user-service</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-parent</artifactId>
        <version>2.0.4.RELEASE</version>
        <relativePath/> <!-- lookup parent from repository -->
    </parent>

    <properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>Finchley.SR1</spring-cloud.version>
    </properties>

    <dependencies>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-actuator</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        </dependency>

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-data-jpa</artifactId>
        </dependency>
        <dependency>
           <groupId>com.h2database</groupId>
           <artifactId>h2</artifactId>
        </dependency>

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


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


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

           <!--  dependency required to use Sampler -->        
         <dependency>
            <groupId>io.zipkin.brave</groupId>
            <artifactId>brave</artifactId>
            <version>4.0.5</version>
        </dependency> 

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


        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
            <scope>runtime</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
            <scope>test</scope>
        </dependency>
    </dependencies>

    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>$spring-cloud.version</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

    <build>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
            </plugin>
        </plugins>
    </build>


</project>

我想有人帮我解决这些问题,我也想了解为什么会出现此异常,以及为什么仅当我添加它的依赖项时才导入采样器类,但我在其他项目代码中看到不需要依赖。

【问题讨论】:

看起来类 zipkin2.reporter.Sender 不在您的类路径中。这可能是由于您使用的库之间的版本冲突引起的。请检查zipkin2 upgrade notes,这些可能会有所帮助。 【参考方案1】:

经过多次搜索,我发现依赖项之间存在版本冲突。 感谢vladimir-vagaytsev

所以,我看到 spring-cloud-starter-sleuth 导入为不同的版本。

为了解决这个问题,我在 pom.xml 中的属性中添加了 sleuth.version,如下所示。

<properties>
        <project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
        <project.reporting.outputEncoding>UTF-8</project.reporting.outputEncoding>
        <java.version>1.8</java.version>
        <spring-cloud.version>Finchley.SR1</spring-cloud.version>
        <sleuth.version>2.0.1.RELEASE</sleuth.version>
    </properties> 

那么在依赖管理中我们需要像这样指定版本

<dependencyManagement>
    <dependencies>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-dependencies</artifactId>
            <version>$spring-cloud.version</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-sleuth</artifactId>
            <version>$sleuth.version</version>
            <type>pom</type>
            <scope>import</scope>
        </dependency>
    </dependencies>
</dependencyManagement>

然后删除未使用的依赖项构建并运行。

【讨论】:

【参考方案2】:

这个类来自 zipkin-2。您可以尝试添加此依赖项。

<dependency>
    <groupId>org.springframework.cloud</groupId>
    <artifactId>spring-cloud-sleuth-zipkin2</artifactId>
    <version>2.0.0.M3</version>
</dependency>

【讨论】:

【参考方案3】:

清除不匹配依赖项的问题只需尝试上下调整依赖项版本就可以了...我的工作是这样的

【讨论】:

正如目前所写,您的答案尚不清楚。请edit 添加其他详细信息,以帮助其他人了解这如何解决所提出的问题。你可以找到更多关于如何写好答案的信息in the help center。

spring-cloud-sleuth 与 spring-amqp 集成

】spring-cloud-sleuth与spring-amqp集成【英文标题】:spring-cloud-sleuthintegrationwithspring-amqp【发布时间】:2016-11-2312:13:17【问题描述】:我只是在使用spring-cloud-sleuth迈出第一步,它适用于各种http调用。现在我正在尝试涵盖消息传递部分... 查看详情

带有 OpenTracing 的 Spring Cloud Sleuth

】带有OpenTracing的SpringCloudSleuth【英文标题】:SpringCloudSleuthwithOpenTracing【发布时间】:2017-10-2506:41:25【问题描述】:有没有办法将SpringCloudSleuth与OpenTracing一起使用?我想用Jaeger连接Spring客户端【问题讨论】:您可以尝试在gitter.i... 查看详情

添加依赖项后,spring-cloud-sleuth 不会在日志中显示任何信息

】添加依赖项后,spring-cloud-sleuth不会在日志中显示任何信息【英文标题】:spring-cloud-sleuthdoesnotshowanyinfoinlogsafteraddingdependencies【发布时间】:2019-06-0310:35:39【问题描述】:我已在我的SpringBoot项目中添加了sleuth依赖项。尽管存在... 查看详情

我们如何在 Spring MVC 项目中使用 Spring Cloud Sleuth?

】我们如何在SpringMVC项目中使用SpringCloudSleuth?【英文标题】:HowcanweuseSpringCloudSleuthwithspringMVCproject?【发布时间】:2020-05-1011:51:21【问题描述】:我正在尝试将springcloudsleuth与springwebmvc项目一起使用。我们正在将来自springwebmvc的... 查看详情

spring-cloud-sleuth简单使用

快速开始一、导入依赖<!--链路追踪start--><dependency><groupId>org.springframework.cloud</groupId><artifactId>spring-cloud-sleuth</artifactId><version>2.0.0.RELEASE</versi 查看详情

反应式环境中的 spring-cloud-sleuth

】反应式环境中的spring-cloud-sleuth【英文标题】:spring-cloud-sleuthinareactiveenvironment【发布时间】:2018-01-0404:59:18【问题描述】:我应该说spring-cloud-sleuth和zipkin的简单性和实用性给我留下了深刻的印象。但是,我正在开发一个POC,... 查看详情

运行集成测试时禁用 Spring Cloud Sleuth?

】运行集成测试时禁用SpringCloudSleuth?【英文标题】:DisableSpringCloudSleuthwhenrunningIntegrationTests?【发布时间】:2019-01-1909:46:20【问题描述】:当使用org.springframework.cloud:spring-cloud-gcp-starter-trace:1.0.0.RELEASE并在本地运行我的集成测试... 查看详情

如何配置 spring-cloud-gateway 以使用 sleuth 记录请求/响应正文

】如何配置spring-cloud-gateway以使用sleuth记录请求/响应正文【英文标题】:Howtoconfigurespring-cloud-gatewaytousesleuthtologrequest/responsebody【发布时间】:2019-03-3111:15:07【问题描述】:我希望开发一个基于spring-cloud-gateway:2.0.2-RELEASE的网关服... 查看详情

spring-cloud-sleuth-zipkin实现微服务的链路跟踪

spring-cloud-sleuth-zipkin实现微服务的链路跟踪简介在微服务数量较多的系统架构中,一个完整的HTTP请求可能需要经过好几个微服务。如果想要跟踪一条完整的HTTP请求链路所产生的日志,我们需要到各个微服务上去查看日志并检索... 查看详情

Spring Cloud Sleuth - 获取当前的 traceId?

】SpringCloudSleuth-获取当前的traceId?【英文标题】:SpringCloudSleuth-GetcurrenttraceId?【发布时间】:2019-12-1700:31:55【问题描述】:我正在使用Sleuth,我想知道是否可以获取当前的traceId?我不需要添加任何响应或任何东西。我只想要在... 查看详情

在 Spring WebFlux 中实现 Spring Cloud Sleuth 的 TracingWebFillter

】在SpringWebFlux中实现SpringCloudSleuth的TracingWebFillter【英文标题】:ImplementSpringCloudSleuth\'sTracingWebFillterinSpringWebFlux【发布时间】:2018-06-3000:58:43【问题描述】:我有一个使用SpringCloudSleuth的功能端点(Kotlin)的SpringBootReactive应用程序... 查看详情

将 spring-cloud-sleuth 添加到类路径时出现“上下文初始化”错误

】将spring-cloud-sleuth添加到类路径时出现“上下文初始化”错误【英文标题】:getting\'ContextInitialization\'errorwhenaddingspring-cloud-sleuthtoclasspath【发布时间】:2018-09-1304:09:52【问题描述】:下面提供了引用spring-cloud-sleuth的构建文件部... 查看详情

在 Spring Cloud sleuth 中不推荐使用 TracingFilter

】在SpringCloudsleuth中不推荐使用TracingFilter【英文标题】:TracingFilterdeprecatedinspringcloudsleuth【发布时间】:2021-11-1509:29:30【问题描述】:似乎TracingFilter在SpringCloudSleuth中已被弃用,我找不到任何替代注入mockMvc的方法,例如:@Autowir... 查看详情

Spring cloud sleuth 注解:自动装配不起作用

】Springcloudsleuth注解:自动装配不起作用【英文标题】:SpringcloudsleuthAnnotations:Autowiringdoesn\'twork【发布时间】:2020-07-1310:21:14【问题描述】:我在我的应用程序中配置了Springcloudsleuth(还有zipkin)。我有一个调用服务的控制器,... 查看详情

sleuth+zipkin服务链路追踪(代码片段)

官方文档:https://cloud.spring.io/spring-cloud-static/spring-cloud-sleuth/2.1.3.RELEASE/single/spring-cloud-sleuth.html一、为什么要用链路追踪微服务架构是一个分布式架构,它按业务划分服务单元,一个分布式系统往往有很多个服务单元... 查看详情

sleuth+zipkin服务链路追踪(代码片段)

官方文档:https://cloud.spring.io/spring-cloud-static/spring-cloud-sleuth/2.1.3.RELEASE/single/spring-cloud-sleuth.html一、为什么要用链路追踪微服务架构是一个分布式架构,它按业务划分服务单元,一个分布式系统往往有很多个服务单元... 查看详情

使用 MySQL 的 Spring Cloud Sleuth

】使用MySQL的SpringCloudSleuth【英文标题】:SpringCloudSleuthwithMySQL【发布时间】:2021-09-0623:14:33【问题描述】:我一直在寻找任何合适的示例来证明我可以找出跟踪并将其存储在本地MySQL数据库中。我使用zipkin服务器来可视化我对微... 查看详情

如何使用 Spring Cloud Sleuth 向每个 span 添加信息

】如何使用SpringCloudSleuth向每个span添加信息【英文标题】:HowtoaddinformationtoeveryspanwithSpringCloudSleuth【发布时间】:2017-12-1507:24:16【问题描述】:我目前正在尝试了解如何以可扩展的方式自定义SpringCloudSleuth以将信息添加到每个Span... 查看详情