- 修复depguard错误:为ops service文件添加redis导入例外 - 修复errcheck错误:添加错误检查和类型断言检查 - 修复gofmt错误:格式化代码 - 修复ineffassign错误:移除无效的idx++赋值 - 修复staticcheck错误:合并条件赋值 - 修复unused错误:移除未使用的字段和函数 - ops_cleanup_service.go: entryID字段 - ops_retry.go: status字段 - ops_upstream_context.go: getOpsUpstreamErrors函数
65 lines
1.5 KiB
Go
65 lines
1.5 KiB
Go
package repository
|
|
|
|
import (
|
|
"fmt"
|
|
"strings"
|
|
)
|
|
|
|
type latencyHistogramBucket struct {
|
|
upperMs int
|
|
label string
|
|
}
|
|
|
|
var latencyHistogramBuckets = []latencyHistogramBucket{
|
|
{upperMs: 100, label: "0-100ms"},
|
|
{upperMs: 200, label: "100-200ms"},
|
|
{upperMs: 500, label: "200-500ms"},
|
|
{upperMs: 1000, label: "500-1000ms"},
|
|
{upperMs: 2000, label: "1000-2000ms"},
|
|
{upperMs: 0, label: "2000ms+"}, // default bucket
|
|
}
|
|
|
|
var latencyHistogramOrderedRanges = func() []string {
|
|
out := make([]string, 0, len(latencyHistogramBuckets))
|
|
for _, b := range latencyHistogramBuckets {
|
|
out = append(out, b.label)
|
|
}
|
|
return out
|
|
}()
|
|
|
|
func latencyHistogramRangeCaseExpr(column string) string {
|
|
var sb strings.Builder
|
|
_ = sb.WriteString("CASE\n")
|
|
|
|
for _, b := range latencyHistogramBuckets {
|
|
if b.upperMs <= 0 {
|
|
continue
|
|
}
|
|
_ = sb.WriteString(fmt.Sprintf("\tWHEN %s < %d THEN '%s'\n", column, b.upperMs, b.label))
|
|
}
|
|
|
|
// Default bucket.
|
|
last := latencyHistogramBuckets[len(latencyHistogramBuckets)-1]
|
|
_ = sb.WriteString(fmt.Sprintf("\tELSE '%s'\n", last.label))
|
|
sb.WriteString("END")
|
|
return sb.String()
|
|
}
|
|
|
|
func latencyHistogramRangeOrderCaseExpr(column string) string {
|
|
var sb strings.Builder
|
|
sb.WriteString("CASE\n")
|
|
|
|
order := 1
|
|
for _, b := range latencyHistogramBuckets {
|
|
if b.upperMs <= 0 {
|
|
continue
|
|
}
|
|
sb.WriteString(fmt.Sprintf("\tWHEN %s < %d THEN %d\n", column, b.upperMs, order))
|
|
order++
|
|
}
|
|
|
|
sb.WriteString(fmt.Sprintf("\tELSE %d\n", order))
|
|
sb.WriteString("END")
|
|
return sb.String()
|
|
}
|