go-zero接入skywalking实现链路追踪的详细教程
Skywalking本地测试搭建
这里用Docker搭建
#数据存储用ES,搭建ES docker run -d -p 9200:9200 -p 9300:9300 --name es -e "discovery.type=single-node" -e ES_JAVA_OPTS="-Xms128m -Xmx256m" elasticsearch:7.16.3 # 搭建skywalking-oap服务,这里用的是8.9.1版本,oap服务需要关联ES docker run --name skywalking-oap \ --restart always \ -p 11800:11800 -p 12800:12800 -d \ -e TZ=Asia/Shanghai \ -e SW_ES_USER= \ -e SW_ES_PASSWORD= \ -e SW_STORAGE=elasticsearch \ -e SW_STORAGE_ES_CLUSTER_NODES=192.168.1.234:9200 \ -v /etc/localtime:/etc/localtime:ro \ apache/skywalking-oap-server:8.9.1 # 搭建skywalking-ui界面,需要关联oap服务 docker run -d \ --name skywalking-ui \ --restart always \ -p 8090:8080 \ --link skywalking-oap:skywalking-oap \ -e TZ=Asia/Shanghai \ -e SW_OAP_ADDRESS=http://skywalking-oap:12800 \ -v /etc/localtime:/etc/localtime:ro \ apache/skywalking-ui:8.9.1
搭建完成,打开ip:8090查看skywalking界面
项目引入
go get github.com/apache/skywalking-go //在main包中引入 import ( _ "github.com/apache/skywalking-go" )
接下来,请从官方 SkyWalking 网站下载Go Agent 程序 。当你使用 go build 命令进行编译时,请在 bin 目录中找到与当前操作系统匹配的代理程序,并添加 -toolexec=“/path/to/go-agent” -a 参数。例如,请使用以下命令:
go build -toolexec=“/path/to/go-agent” -a -o test .
在skywalking-go/bin路径下生成可执行文件。
不同的操作系统对应的可执行文件不同。例如,mac系统需选择skywalking-go-agent–darwin-amd64。(亲测相应文件在window系统执行会报错,在linux和mac系统正常)
dockerfile打包引入
相应的Agent程序skywalking-go-agent放在项目./doc/tool/目录下,并设置环境变量,具体看dockerfile
ENV SW_AGENT_NAME=go-${param} ENV SW_AGENT_REPORTER_GRPC_BACKEND_SERVICE=skywalking-oap.skywalking.svc.cluster.local:11800 ENV SW_AGENT_REPORTER_GRPC_CDS_FETCH_INTERVAL=-1
FROM golang:1.22-alpine AS builder LABEL stage=gobuilder ENV GOPROXY https://goproxy.cn,direct RUN sed -i 's/dl-cdn.alpinelinux.org/mirrors.aliyun.com/g' /etc/apk/repositories RUN apk update --no-cache && apk add --no-cache tzdata # 设置工作目录 WORKDIR /build # 加载依赖 ADD go.mod . ADD go.sum . RUN go mod download # 复制源代码 COPY . . # 静态编译Go程序 RUN CGO_ENABLED=0 GOOS=linux GOARCH=amd64 go build -ldflags="-s -w" -toolexec="/build/doc/tool/skywalking-go-agent" -a -o app ./service/${struct_name}Service/${param}.go # 第二阶段:运行时镜像,使用空镜像scratch或者alpine FROM alpine COPY --from=builder /etc/ssl/certs/ca-certificates.crt /etc/ssl/certs/ca-certificates.crt # 设置工作目录 WORKDIR /app # 复制编译好的二进制文件到运行时镜像 COPY --from=builder /build/app . COPY --from=builder /build/i18n /app/i18n COPY --from=builder /build/key/google_play_service_account_key.json /etc/ssl/certs/google_play_service_account_key.json COPY --from=builder /build/key/SubscriptionKey_23HSTRGFC3.p8 /etc/ssl/certs/SubscriptionKey_23HSTRGFC3.p8 # 设置 SkyWalking Agent 的配置 ENV SW_AGENT_NAME=go-${param} ENV SW_AGENT_REPORTER_GRPC_BACKEND_SERVICE=skywalking-oap.skywalking.svc.cluster.local:11800 ENV SW_AGENT_REPORTER_GRPC_CDS_FETCH_INTERVAL=-1 # 运行程序 ENTRYPOINT ["./app"] # 设置CMD指令来指定参数,默认测试环境的etcd CMD ["16.162.220.93:2379"]
最后效果图
以上就是go-zero接入skywalking链路追踪的详细教程的详细内容,更多关于go-zero skywalking链路追踪的资料请关注脚本之家其它相关文章!
相关文章
Go基础教程系列之defer、panic和recover详解
这篇文章主要介绍了Go基础教程系列之defer、panic和recover,需要的朋友可以参考下2022-04-04Golang中字符串(string)与字节数组([]byte)一行代码互转实例
golang语言本身就是c的工具集,开发c的程序用到的大部分结构体,内存管理,携程等,golang基本都有,下面这篇文章主要给大家介绍了关于Golang中字符串(string)与字节数组([]byte)一行代码互转的相关资料,需要的朋友可以参考下2022-09-09
最新评论