配置环境变量
OTEL_TRACES_EXPORTER=otlp \
OTEL_EXPORTER_OTLP_ENDPOINT=http://192.168.91.11:4317 \
OTEL_EXPORTER_OTLP_TIMEOUT=10000 \
java -javaagent:opentelemetry-javaagent.jar \
-Dotel.resource.attributes=service.name=server \
-Dotel.javaagent.debug=false \
-Dotel.metrics.exporter=none \
-Dotel.propagators=b3 \
-jar springboot-server.jar --client=false
java -javaagent:../opentelemetry-javaagent/opentelemetry-javaagent.jar \
-Dotel.traces.exporter=otlp \
-Dotel.exporter.otlp.endpoint=http://192.168.91.11:4317 \
-Dotel.resource.attributes=service.name=server \
-Dotel.metrics.exporter=none \
-Dotel.propagators=b3 \
-jar springboot-server.jar --client=false
如果需要与前端链路打通,则需要保证前后端链路采用的是同一种类型的传播器
-Dotel.propagators=b3
开启client
curl http://localhost:8080/setClient?c=true
关闭client
curl http://localhost:8080/setClient?c=false
查看当前client状态
curl http://localhost:8080/getClient
应用 server 和 client 将 log 通过 otlp-exporter push 到 otel-collector,再通过 otel-collector exporter 到 Elasticsearch。 修改启动参数
需要在应用启动时添加参数-Dotel.logs.exporter=otlp
主要是通过 Logstash-logback 提供的 socket 方式将日志上传到 Logstash 上,需要对代码做部分调整。
启动的时候指定logstash相关参数
--spring.profiles.active=logstash \
--logstash.host=localhost \
--logstash.port=4560
https://github.com/lrwh/observable-demo/blob/main/springboot-client
https://github.com/lrwh/observable-demo/blob/main/opentelemetry-js
效果图:
目前已推送到阿里云docker仓库
其中内置opentelemetry-javaagent.jar
版本为1.13.1
docker pull registry.cn-shenzhen.aliyuncs.com/lr_715377484/springboot-server:latest
# 启动 docker mongo
docker run -d -p 27017:27017 --name some-mongo -e MONGO_INITDB_ROOT_USERNAME=mongoadmin -e MONGO_INITDB_ROOT_PASSWORD=secret mongo:6.0
# 进入容器
docker exec -it some-mongo mongosh
# 创建 appdb
use appdb
use admin
# 认证
admin> db.auth("mongoadmin","secret");
# 创建 appdb 用户
db.createUser({user:"appAdmin",pwd:"123456",roles:[{role:"readWrite",db:"appdb"}]})