1 Star 0 Fork 0

go-libs/log

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
context.go 2.59 KB
一键复制 编辑 原始数据 按行查看 历史
非一般 提交于 2024-12-10 12:43 . add: NewContextWithHeader
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
//
// Author: wsfuyibing <682805@qq.com>
// Date: 2024-11-12
package common
import (
"context"
"fmt"
"gitee.com/go-libs/log/conf"
"net/http"
)
const (
ContextKey = "__GO_LIB_LOG_TRACING__"
)
// AttachRequest
// 向 <http.Request> 添加兼容 OpenTracing 的 <common.Tracing> 参数.
func AttachRequest(ctx context.Context, req *http.Request) {
if v := GetContextTracing(ctx); v != nil {
cfg := conf.New()
sid, sp := v.GetSpan()
tid := v.GetTraceId()
req.Header.Set(cfg.OpenTracingSampled, "1")
req.Header.Set(cfg.OpenTracingSpanId, sid.String())
req.Header.Set(cfg.OpenTracingSpanPosition, fmt.Sprintf(`%v`, sp))
req.Header.Set(cfg.OpenTracingTraceId, tid.String())
}
}
// GetContextHeader
// 从 <context.Context> 提取 <http.Header> 参数.
func GetContextHeader(ctx context.Context) http.Header {
if v := GetContextTracing(ctx); v != nil {
cfg := conf.New()
sid, sp := v.GetSpan()
tid := v.GetTraceId()
if sp > 0 {
sp -= 1
}
header := make(http.Header)
header.Set(cfg.OpenTracingSampled, "1")
header.Set(cfg.OpenTracingSpanId, sid.String())
header.Set(cfg.OpenTracingSpanPosition, fmt.Sprintf(`%v`, sp))
header.Set(cfg.OpenTracingTraceId, tid.String())
return header
}
return nil
}
// GetContextTracing
// 从 <context.Context> 提取 <common.Tracing>.
func GetContextTracing(ctx context.Context) Tracing {
if v, ok := ctx.Value(ContextKey).(Tracing); ok {
return v
}
return nil
}
// SetContextTracing
// 设置 <common.Tracing> 到 <context.Context>.
func SetContextTracing(ctx context.Context, tracing Tracing) context.Context {
return context.WithValue(ctx, ContextKey, tracing)
}
// NewContext
// 创建上下文.
func NewContext(cts ...context.Context) context.Context {
if len(cts) > 0 && cts[0] != nil {
if v := GetContextTracing(cts[0]); v != nil {
return SetContextTracing(cts[0], v.Child())
}
}
return SetContextTracing(context.Background(), NewTracing())
}
func NewContextWithHeader(header http.Header) context.Context {
return SetContextTracing(context.Background(), NewTracingWithHeader(header))
}
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/go-libs/log.git
git@gitee.com:go-libs/log.git
go-libs
log
log
v1.1.9

搜索帮助

0d507c66 1850385 C8b1a773 1850385