当前位置: 首页 > news >正文

网站禁止ping济南it培训机构

网站禁止ping,济南it培训机构,外贸网站建设 义乌,无极在线招聘最新消息由上文分布式链路追踪入门篇-基础原理与快速应用可以知道分布式链路追踪的作用#xff0c;但是距离应用到项目中#xff0c;我们还需要对项目中一些关键组件进行opentelemetry的集成#xff0c;例如日志库#xff0c;ORM、http框架、rpc框架等。 一、日志库如何集成opentel… 由上文分布式链路追踪入门篇-基础原理与快速应用可以知道分布式链路追踪的作用但是距离应用到项目中我们还需要对项目中一些关键组件进行opentelemetry的集成例如日志库ORM、http框架、rpc框架等。 一、日志库如何集成opentelemetry 其实对日志库的集成无非就是调用日志库的方法进行日志打印时可以把日志信息也被记录下来推送到可视化的后端eg:jaeger。而由上文分布式链路追踪入门篇-基础原理与快速应用可以知道通过span可以关联上相关的操作信息 二、简单demo演示 例如就对我们go原生的log库进行封装 log.go package pkgimport (contextlogosgo.opentelemetry.io/otel/attributego.opentelemetry.io/otel/trace )//封装一下日志 type Logger struct {log *log.Logger }var Log *Loggerfunc init() {Log Logger{log: log.New(os.Stderr, , log.LstdFlags),} }func (l *Logger) Debug(ctx context.Context, msg string) {span : trace.SpanFromContext(ctx)span.AddEvent(, trace.WithAttributes(attribute.String(log, msg)))l.log.Println(msg) }//todo 原生日志库只有Print方法没有INFO、WARNd等分级 func (l *Logger) Info(ctx context.Context, msg string) {} //todo func (l *Logger) Warn(ctx context.Context, msg string) {} //todo func (l *Logger) Error(ctx context.Context, msg string) {} //todo func (l *Logger) Fatal(ctx context.Context, msg string) {}main.go package mainimport (contextfmtlognet/httpgo.opentelemetry.io/otelgo.opentelemetry.io/otel/exporters/trace/jaegergo.opentelemetry.io/otel/sdk/resourcesdktrace go.opentelemetry.io/otel/sdk/tracego.opentelemetry.io/otel/semconvotel/log/pkg )// 初始化 OpenTelemetry func initTracer() *sdktrace.TracerProvider {exporter, err : jaeger.NewRawExporter(jaeger.WithAgentEndpoint(func(options *jaeger.AgentEndpointOptions) {options.Host localhostoptions.Port 6831}),)if err ! nil {log.Fatalf(Error creating Jaeger exporter: %v, err)}tp : sdktrace.NewTracerProvider(sdktrace.WithBatcher(exporter),sdktrace.WithSampler(sdktrace.AlwaysSample()),sdktrace.WithResource(resource.NewWithAttributes(semconv.ServiceNameKey.String(demo_service), // 服务名)),)otel.SetTracerProvider(tp)return tp }func main() {tp : initTracer()defer func() {if cerr : tp.Shutdown(context.Background()); cerr ! nil {log.Fatalf(Error shutting down tracer provider: %v, cerr)}}()//启动http服务器http.HandleFunc(/log/demo, handleRequest)go func() {if err : http.ListenAndServe(:8080, nil); err ! nil {log.Fatalf(Error starting Service A server: %v, err)}}()//模拟请求SimulateRequest() }func SimulateRequest() {req, err : http.NewRequest(GET, http://localhost:8080/log/demo, nil)if err ! nil {log.Fatalf(Creating request fail: %v, err)}resp, err : http.DefaultClient.Do(req)if err ! nil {log.Fatalf(Request failed: %v, err)}defer resp.Body.Close()fmt.Println(Response received from Root Service) }func handleRequest(w http.ResponseWriter, req *http.Request) {tracer : otel.Tracer(root)//开始创建root spanctx, span : tracer.Start(req.Context(), root service)defer span.End()pkg.Log.Debug(ctx, this is root service)//访问服务AcallServiceA(ctx)w.WriteHeader(http.StatusOK)fmt.Fprintf(w, Response from Service Root) }// Service A func callServiceA(ctx context.Context) {tracer : otel.Tracer(service A)ctx, span : tracer.Start(ctx, ServiceA)defer span.End()pkg.Log.Debug(ctx, this is A service)fmt.Println(Service A) }运行程序后访问jeager 三、总结 1. 其实日志库的集成就是对原先的日志库进行一层封装日志打印方法传入上下文通过上下文获取到操作单元span然后给span关联上日志信息 2. 上面demo只是一个演示我们也可以依照这个思路封装我们自己项目中的日志库
http://www.zqtcl.cn/news/443487/

相关文章:

  • linux 网站搬家wordpress 卸载plugin
  • 江苏省建设厅网站 投诉编辑网站的软件手机
  • 深圳地图各区分布图seo网络优化师就业前景
  • 北京网站备案代理国家企业信用信息公示系统广东
  • 推销网站重庆网站优化公司哪家便宜
  • 外贸公司网站搭建礼品网站建设
  • 网站建设 今晟网络中国制造网官网登录
  • 东莞网站设计如何常州做网站设计
  • php网站数据库修改网站备案有必要吗
  • 电商会学着做网站呢WordPress又拍云cdn
  • 网站健设推广产品多少钱网站规划有什么意义
  • 诚信网站备案中心内江网站建设新闻
  • 品牌形象网站有哪些百度应用中心
  • 网站建设找什么工作室甜点网站建设的功能及意义
  • wordpress 近期文章seo排名优化推广
  • 网页设计制作网站素材网站程序哪个好
  • 郑州好的网站设计公司软件开发哪里学好
  • 网站新建设请示软件外包平台哪家可信赖
  • 做阿里巴巴还是做网站好安卓手机怎么做网站
  • 社区智慧警务网站如何推进警务室建设方案广东网络推广服务
  • 东莞艺美网站建设wordpress get header
  • 做玩具什么 网站比较好网址域名
  • 网站做用户登录中国建设部官方网站资格证查询
  • 济宁网站建设公司大型餐饮网站建设
  • 昊源建设监理有限公司网站做那种的视频网站有哪些
  • wordpress滑块代码seo外链增加
  • 衡阳网站建设公司地址书店网站怎么做
  • 如何检查网站是否做cdn加速html网页基础代码
  • 做网站的岗位好吗钓鱼网站到底怎么做
  • 大连做网站那个公司最好wordpress+高清背景