-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsaveTraceContextConsumer.go
91 lines (82 loc) · 3.33 KB
/
saveTraceContextConsumer.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
package linkTrace
import (
"bytes"
"crypto/tls"
"fmt"
"net/http"
"strconv"
"github.com/farseer-go/collections"
"github.com/farseer-go/fs/configure"
"github.com/farseer-go/fs/core"
"github.com/farseer-go/fs/exception"
"github.com/farseer-go/fs/flog"
"github.com/farseer-go/fs/snc"
"github.com/farseer-go/fs/trace"
"github.com/farseer-go/fs/trace/eumTraceType"
)
// FopsServer fops地址
var FopsServer string
// SaveTraceContextConsumer 上传链路记录到FOPS中心
func SaveTraceContextConsumer(subscribeName string, lstMessage collections.ListAny, remainingCount int) {
if traceContext := trace.CurTraceContext.Get(); traceContext != nil {
traceContext.Ignore()
}
lstTraceContext := collections.NewList[*trace.TraceContext]()
lstMessage.Foreach(func(item *any) {
// 上下文
dto := (*item).(*trace.TraceContext)
if len(dto.List) == 0 && dto.TraceType != eumTraceType.WebApi {
return
}
// 链路超过200条,则丢弃
if len(dto.List) > 200 {
dto.List = dto.List[0:200]
switch dto.TraceType {
case eumTraceType.WebApi:
flog.Warningf("【%s链路追踪】链路明细超过200条,TraceId:%s,耗时:%s,%s", dto.TraceType.ToString(), flog.Green(dto.TraceId), flog.Red(dto.UseTs.String()), dto.WebContext.WebPath)
case eumTraceType.MqConsumer, eumTraceType.QueueConsumer, eumTraceType.EventConsumer:
flog.Warningf("【%s链路追踪】链路明细超过200条,TraceId:%s,耗时:%s,%s", dto.TraceType.ToString(), flog.Green(dto.TraceId), flog.Red(dto.UseTs.String()), dto.ConsumerContext.ConsumerQueueName)
case eumTraceType.Task, eumTraceType.FSchedule:
flog.Warningf("【%s链路追踪】链路明细超过200条,TraceId:%s,耗时:%s,%s %s", dto.TraceType.ToString(), flog.Green(dto.TraceId), flog.Red(dto.UseTs.String()), dto.TaskContext.TaskName, dto.TaskContext.TaskGroupName)
default:
flog.Warningf("【%s链路追踪】链路明细超过200条,TraceId:%s,耗时:%s", dto.TraceType.ToString(), flog.Green(dto.TraceId), flog.Red(dto.UseTs.String()))
}
}
lstTraceContext.Add(dto)
})
if err := uploadTrace(lstTraceContext); err != nil {
exception.ThrowRefuseException(err.Error())
}
}
type UploadTraceRequest struct {
List any
}
// UploadTrace 上传链路记录
func uploadTrace(lstTraceContext collections.List[*trace.TraceContext]) error {
bodyByte, _ := snc.Marshal(UploadTraceRequest{List: lstTraceContext})
url := configure.GetFopsServer() + "linkTrace/upload"
newRequest, _ := http.NewRequest("POST", url, bytes.NewReader(bodyByte))
newRequest.Header.Set("Content-Type", "application/json")
// 链路追踪
if traceContext := trace.CurTraceContext.Get(); traceContext != nil {
newRequest.Header.Set("Trace-Id", traceContext.TraceId)
newRequest.Header.Set("Trace-Level", strconv.Itoa(traceContext.TraceLevel))
newRequest.Header.Set("Trace-App-Name", core.AppName)
}
client := &http.Client{
Transport: &http.Transport{
TLSClientConfig: &tls.Config{
InsecureSkipVerify: true, // 不验证 HTTPS 证书
},
},
}
rsp, err := client.Do(newRequest)
if err != nil {
return fmt.Errorf("上传链路记录到FOPS失败:%s", err.Error())
}
apiRsp := core.NewApiResponseByReader[any](rsp.Body)
if apiRsp.StatusCode != 200 {
return fmt.Errorf("上传链路记录到FOPS失败(%v):%s", apiRsp.StatusCode, apiRsp.StatusMessage)
}
return err
}