skywalking
快速开始
1、下载依赖包
go get -u github.com/SkyAPM/go2sky
go get github.com/SkyAPM/go2sky-plugins/gin/v3
如果项目中同时使用到 etcd,可能会出现依赖包冲突的情况,经过测试可将上述两个依赖包降级为 0.6.0 版本
2、创建示例
package main
import (
"fmt"
"time"
"github.com/SkyAPM/go2sky"
"github.com/SkyAPM/go2sky/reporter"
"github.com/gin-gonic/gin"
v3 "github.com/SkyAPM/go2sky-plugins/gin/v3"
)
var (
skyAddr = "localhost:11800
serverName = "echo-server"
serverPort = 8080
)
func panicErr(err error){
if err!=nil{
panic(err)
}
}
func main() {
r := gin.Default()
// 实例化 grpc 连接到 skywalking-oap 服务
rp, err := reporter.NewGRPCReporter(skyAddr, reporter.WithCheckInterval(5*time.Second))
panicErr(err)
// 实例化链路追踪器,每个追踪器对应一个注册服务,通常情况下使用单例模式
tracer, err := go2sky.NewTracer(serverName, go2sky.WithReporter(rp))
panicErr(err)
// 将链路追踪器注册到 gin 中间件,自动记录入站请求
r.Use(v3.Middleware(r, tracer))
// 自定义接口方法,并记录调用过程
r.GET("/hello", func(ctx *gin.Context) {
// 创建一个 span 用于记录入站后的本地处理过程,使用 CreateLocalSpan,如果是 入站请求,则使用 CreateEntrySpan(由于中间件已完成注入,此处已省略)
span, spanCtx, err := tracer.CreateLocalSpan(context.Request.Context())
panicErr(err)
// 设置当前 span 操作步骤的名称
span.SetOperationName("SayHello")
// 使用 span 上下文替换原本 gin 的上下文,其中包括追踪过程所记录的信息
ctx.Request = ctx.Request.WithContext(spanCtx)
// 记录追踪日志
span.Log(time.Now(), serverName + ": hello")
result := gin.H{
"msg": "hello",
}
ctx.JSON(200, result)
// 结束 span,完成一个过程记录
span.End()
})
r.Run(fmt.Sprintf(":%d", serverPort))
}
最后更新于
这有帮助吗?