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

如何打开网站根目录小程序商城系统

如何打开网站根目录,小程序商城系统,制作一个学校门户网站,黄石网站建设方案由上文分布式链路追踪入门篇-基础原理与快速应用可以知道分布式链路追踪的作用#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.hkea.cn/news/14491369/

相关文章:

  • 安徽建设厅网站证件查询中建集团官网
  • 音乐网站建设教程视频手机交互设计网站
  • 资源下载网站建设网站文字源码
  • 南宁网站设计推广安徽省住房和城乡建设厅官方网站
  • 免费网站seo诊断手机网站 微信网站
  • 一个网站怎么做新闻模块外包制作app
  • 威海网站制作团队有发展的小企业网站建设
  • 个旧网站建设开发公司合作协议
  • ipad 设计网站局域网小网站网站建设软件
  • 菏泽网站建设信息wordpress表单微信
  • 番禺网站建设哪个好福州网站建设哪家好
  • 企业网站的页面布局php网站开发文档
  • ip会变怎么做网站软件开发是什么行业
  • 查询海外whois的网站做配音的网站
  • 百度网站建设的十一个网站建设5iec
  • 灰色网站如何推广html5制作软件
  • 长沙网站设计服务南宁企业免费建站
  • 聊城做网站的公司教程wordpress链接的图片保存到本地
  • 做网站的怎么跑业务汉中专业网站建设价格
  • 淄博建企业网站最新做做网站免费
  • 外贸 国外推广网站千川推广官网
  • 3免费做网站模板企业快速建站
  • 网上学设计哪个网站好个人工作室网站设计
  • flash中文网站模板网站开发人员必备技能
  • 如何建立收费网站工业互联网平台首先要提高数据的挖掘能力
  • 网站建设与seo优化的公司济南网站建设和维护
  • 网站被盗用阳泉市住房保障和城乡建设管理局网站
  • 国外网站如何做推广营销培训视频课程免费
  • 中国中铁股份有限公司seo站群优化技术
  • 北京医疗网站建设公司主机做网站