codecamp

Kitex 埋点粒度

埋点粒度

埋点粒度:

  1. LevelDisabled 禁用埋点
  2. LevelBase 仅启用基本埋点
  3. LevelDetailed 启用基本埋点和细粒度埋点

默认埋点策略:

  1. 无 tracer 时,默认 LevelDisabled
  2. 有 tracer 时,默认 LevelDetailed

客户端埋点粒度控制:

import "github.com/cloudwego/kitex/client"
import "github.com/cloudwego/kitex/pkg/stats"
...
baseStats := client.WithStatsLevel(stats.LevelBase)
client, err := echo.NewClient("echo", baseStats)
if err != nil {
	log.Fatal(err)
}

服务端埋点粒度控制:

import "github.com/cloudwego/kitex/server"
import "github.com/cloudwego/kitex/pkg/stats"
...
baseStats := server.WithStatsLevel(stats.LevelBase)
svr, err := echo.NewServer(baseStats)
if err := svr.Run(); err != nil {
	log.Println("server stopped with error:", err)
} else {
	log.Println("server stopped")
}

埋点说明

基本埋点:

  1. RPCStart,(客户端 / 服务端)RPC 调用开始
  2. RPCFinish,(客户端 / 服务端)RPC 调用结束

细粒度埋点(客户端):

  1. ClientConnStart,连接建立开始
  2. ClientConnFinish,连接建立结束
  3. WriteStart,请求发送(含编码)开始
  4. WriteFinish,请求发送(含编码)结束
  5. ReadStart,响应接收(含解码)开始
  6. WaitReadStart,响应二进制读取开始(仅适用于 Fast Codec)
  7. WaitReadFinish,响应二进制读取完毕(仅适用于 Fast Codec)
  8. ReadFinish,响应接收(含解码)完毕

细粒度埋点(服务端):

  1. ReadStart,请求接收(含解码)开始
  2. WaitReadStart,请求二进制读取开始(仅适用于 Fast Codec)
  3. WaitReadFinish,请求二进制读取完毕(仅适用于 Fast Codec)
  4. ReadFinish,请求接收(含解码)完毕
  5. ServerHandleStart,handler 处理开始
  6. ServerHandleFinish,handler 处理完毕
  7. WriteStart,响应发送(含编码)开始

WriteFinish,响应发送(含编码)结束

时序图:

客户端埋点时序图


服务端埋点时序图



Kitex 限流
Kitex 日志
温馨提示
下载编程狮App,免费阅读超1000+编程语言教程
取消
确定
目录

关闭

MIP.setData({ 'pageTheme' : getCookie('pageTheme') || {'day':true, 'night':false}, 'pageFontSize' : getCookie('pageFontSize') || 20 }); MIP.watch('pageTheme', function(newValue){ setCookie('pageTheme', JSON.stringify(newValue)) }); MIP.watch('pageFontSize', function(newValue){ setCookie('pageFontSize', newValue) }); function setCookie(name, value){ var days = 1; var exp = new Date(); exp.setTime(exp.getTime() + days*24*60*60*1000); document.cookie = name + '=' + value + ';expires=' + exp.toUTCString(); } function getCookie(name){ var reg = new RegExp('(^| )' + name + '=([^;]*)(;|$)'); return document.cookie.match(reg) ? JSON.parse(document.cookie.match(reg)[2]) : null; }