使用 Spring Cloud Sleuth 将跟踪数据发送到 OpenZIpkin

Mar*_*rco 1 spring zipkin spring-cloud-sleuth

更新:我已将代码推送到我的存储库中,以便人们可以查看那里以了解可能出了什么问题。

编辑:我几乎可以肯定是客户端代码没有将任何统计信息发布到服务器,但是下面的指南都没有解释应该如何启用它:是否有我缺少的配置设置?

我一直在关注OpenZipkinSpring Sleuth的快速入门:我有一个来自docker-zipkin的正在运行的 Zipkin 服务器,使用docker-composeCassandra 作为后端:

$ d ps
CONTAINER ID        IMAGE                                COMMAND                  CREATED             STATUS              PORTS                                                                               NAMES
5ca0f0b29900        openzipkin/zipkin:1.12.1             "/bin/sh -c 'test -n "   14 minutes ago      Up 8 minutes        0.0.0.0:9410-9411->9410-9411/tcp                                                    zipkin
7b243a0b61e3        openzipkin/zipkin-dependencies       "crond -f"               14 minutes ago      Up 8 minutes                                                                                            dependencies
e2e047fb3851        openzipkin/zipkin-cassandra:1.12.1   "/bin/sh -c /usr/loca"   14 minutes ago      Up 8 minutes        7000-7001/tcp, 0.0.0.0:3306->3306/tcp, 7199/tcp, 0.0.0.0:9042->9042/tcp, 9160/tcp   cassandra
Run Code Online (Sandbox Code Playgroud)

我已经创建并运行了Spring Sleuth 示例应用程序,它似乎已正确配置以跟踪调用:

# application.properties)
server.port = 9099
spring.application.name = zipkin-demo
spring.zipkin.baseUrl = http://localhost:9411/
spring.sleuth.sampler.percentage = 1.0
Run Code Online (Sandbox Code Playgroud)

日志似乎表明应该记录跟踪:

2016-10-04 15:20:02.115  INFO [zipkin-demo,c6e06ff47bddaf4d,f7437cf1c7089522,true] 70899 --- [nio-9099-exec-3] com.apple.its.api.ApiController          : Forwarding to http://localhost:8088/api/v1/hello
2016-10-04 15:20:02.709  INFO [zipkin-demo,de3c25ea46e8b010,f7e6017757f0ce5e,true] 70899 --- [nio-9099-exec-4] com.apple.its.api.ApiController          : Forwarding to http://localhost:8088/api/v1/hello
2016-10-04 15:20:06.480  INFO [zipkin-demo,4c9fdeaab69b79b4,1dc8b9b7ce5c6fa5,true] 70899 --- [nio-9099-exec-5] com.apple.its.api.ApiController          : Sleeping for [278] millis
2016-10-04 15:20:08.833  INFO [zipkin-demo,2eb26be1a6867e5,b566753eb137026,true] 70899 --- [nio-9099-exec-8] com.apple.its.api.ApiController          : Sleeping for [467] millis
2016-10-04 15:20:10.608  INFO [zipkin-demo,eec83e7fc4ea9c9d,c88723b29ca4335c,true] 70899 --- [nio-9099-exec-1] com.apple.its.api.ApiController          : Sleeping for [20] millis
2016-10-04 15:20:12.035  INFO [zipkin-demo,63259dd1bac357e9,5cf013d16bb1ee98,true] 70899 --- [nio-9099-exec-4] com.apple.its.api.ApiController          : Sleeping for [22] millis
Run Code Online (Sandbox Code Playgroud)

但是,无论我做什么,UI 都不会显示任何痕迹。奇怪的是,它localhost:9411/trace确实显示了一堆痕迹(它们似乎主要来自 Zipkin 本身)但没有来自zipkin-demo应用程序。

我相信这是因为演示应用程序没有将跟踪发送到主机,但我只是使用Spring 的示例应用程序,那么我做错了什么?

Mar*_*zak 5

如果我没有弄错(我想我没有弄错),难怪您没有将 Span 发送到 Zipkin,因为您没有添加 Zipkin 依赖项。通过文档的HTTP部分使用 Zipkin检查Sleuthhttp : //cloud.spring.io/spring-cloud-sleuth/spring-cloud-sleuth.html

dependencyManagement {
    imports {
        mavenBom "org.springframework.cloud:spring-cloud-dependencies:Brixton.RELEASE"
    }
}
dependencies {
    compile "org.springframework.cloud:spring-cloud-starter-zipkin"
}
Run Code Online (Sandbox Code Playgroud)