我们如何在SpringMVC项目中使用SpringCloudSleuth?

我们如何在SpringMVC项目中使用SpringCloudSleuth?,spring,spring-boot,spring-mvc,spring-cloud,spring-cloud-sleuth,Spring,Spring Boot,Spring Mvc,Spring Cloud,Spring Cloud Sleuth,我正在尝试将SpringCloudSleuth与SpringWebMVC项目结合使用。我们正在将请求从SpringWebMVC发送到另一个SpringBoot项目。我需要在UI中显示traceID和spanId。我们如何才能做到这一点 编辑 spring引导应用程序的POM.xml。我正在使用最新版本的Spring Boot,并添加了Spring cloud sleuth的依赖项 <parent> <groupId>org.springframework.boot

我正在尝试将SpringCloudSleuth与SpringWebMVC项目结合使用。我们正在将请求从SpringWebMVC发送到另一个SpringBoot项目。我需要在UI中显示traceID和spanId。我们如何才能做到这一点

编辑

spring引导应用程序的POM.xml。我正在使用最新版本的Spring Boot,并添加了Spring cloud sleuth的依赖项

<parent>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-starter-parent</artifactId>
    <version>2.2.4.RELEASE</version>
    <relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.test</groupId>
<artifactId>demo</artifactId>
<version>0.0.1-SNAPSHOT</version>
<name>demo</name>
<description>Demo project for Spring Boot</description>

<properties>
    <java.version>1.8</java.version>
    <spring-cloud.version>Hoxton.SR1</spring-cloud.version>
</properties>

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

    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-test</artifactId>
        <scope>test</scope>
        <exclusions>
            <exclusion>
                <groupId>org.junit.vintage</groupId>
                <artifactId>junit-vintage-engine</artifactId>
            </exclusion>
        </exclusions>
    </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>

org.springframework.boot
spring启动程序父级
2.2.4.1发布
com.test
演示
0.0.1-快照
演示
SpringBoot的演示项目
1.8
Hoxton.SR1
org.springframework.boot
SpringBootStarterWeb
org.springframework.cloud
斯普林云侦探
org.springframework.boot
弹簧起动试验
测试
org.junit.vintage
朱尼特老式发动机
org.springframework.cloud
spring云依赖关系
${spring cloud.version}
聚甲醛
进口
org.springframework.boot
springbootmaven插件
WebMVC代码:我正在使用SpringREST模板,并从SpringWebMVC应用程序调用SpringBoot服务

@Controller
public class HelloController {

    @Autowired
    RestTemplate restTemplate;

    private Logger logger = Logger.getLogger(HelloController.class);

    @GetMapping("/hello")
    public String hello(Model model) {
        logger.info("Hello from controller");
        ResponseEntity<String> entity = restTemplate.getForEntity("http://localhost:8092/test", String.class);
        String response = entity.getBody();
        logger.info("Response from Service: "+ response);
        model.addAttribute("name", "Test");
        return "welcome";
    }
}
@控制器
公共类Hello控制器{
@自动连线
rest模板rest模板;
专用记录器=Logger.getLogger(HelloController.class);
@GetMapping(“/hello”)
公共字符串hello(模型){
logger.info(“来自控制器的你好”);
ResponseEntity=restTemplate.getForEntity(“http://localhost:8092/test“,String.class);
字符串响应=entity.getBody();
logger.info(“来自服务的响应:”+响应);
model.addAttribute(“名称”、“测试”);
返回“欢迎”;
}
}


要做到这一点,需要注入
跟踪器
bean,如果调用
Tracer.currentSpan().context().traceIdString()
Tracer.currentSpan().context().spanIdString()
要做到这一点,需要注入
跟踪器
bean,如果调用
Tracer.currentSpan().context()?您使用的是RestTemplate吗?是的,我使用的是RestTemplate。您是否可以共享spring boot应用程序的pom.xml,以及spring mvc应用程序的示例代码[调用spring boot应用程序的代码]添加了pom.xml和web mvc代码当您说要在UI上显示span_id和trace_id时,它是指你的应用程序的UI,还是你可以想到类似zipkin的东西,在那里你可以根据span\u id/trace\u id等进行查看和搜索。你如何调用你的spring boot项目?您使用的是RestTemplate吗?是的,我使用的是RestTemplate。您是否可以共享spring boot应用程序的pom.xml,以及spring mvc应用程序的示例代码[调用spring boot应用程序的代码]添加了pom.xml和web mvc代码当您说要在UI上显示span_id和trace_id时,它是指应用程序的UI,还是您可以想到zipkin之类的东西,在那里您可以根据span\u id/trace\u id等进行查看和搜索。我们可以在跟踪日志时使用此跟踪id和span\u id吗?我的意思是,我们需要一个相关ID,我们在UI中使用它(比如zipkin),对不起,我不理解这个问题。如果您使用Sleuth,您将获得完整的日志关联,日志中确实包含跟踪id和span id。在提问之前,您是否尝试过使用此方法?或者您确实使用了它,但在日志中看不到跟踪id和span id?您是否更改了默认的日志记录格式?一般来说,如果您只是将starter sleuth添加到类路径中,您就可以直接获得日志关联。是的,我尝试过使用sleuth,但实际问题是,即使在更改日志格式之后,我在spring MVC项目中也无法获得跟踪/span id。我可以在spring boot项目中看到相关id,但在spring MVC项目中看不到。没有spring boot,Sleuth将无法工作。您可以直接使用project Brave而不是我是否需要在spring MVC和spring Boot应用程序中配置Brave?我们可以在跟踪日志时使用此跟踪id和span_id吗?我的意思是,我们需要一个相关ID,我们在UI中使用它(比如zipkin),对不起,我不理解这个问题。如果您使用Sleuth,您将获得完整的日志关联,日志中确实包含跟踪id和span id。在提问之前,您是否尝试过使用此方法?或者您确实使用了它,但在日志中看不到跟踪id和span id?您是否更改了默认的日志记录格式?一般来说,如果您只是将starter sleuth添加到类路径中,您就可以直接获得日志关联。是的,我尝试过使用sleuth,但实际问题是,即使在更改日志格式之后,我在spring MVC项目中也无法获得跟踪/span id。我可以在spring boot项目中看到相关id,但在spring MVC项目中看不到。没有spring boot,Sleuth将无法工作。您可以直接使用ProjectBrave,而不是我是否需要在SpringMVC和SpringBoot应用程序中配置Brave?