<ruby id="bdb3f"></ruby>

    <p id="bdb3f"><cite id="bdb3f"></cite></p>

      <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
        <p id="bdb3f"><cite id="bdb3f"></cite></p>

          <pre id="bdb3f"></pre>
          <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

          <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
          <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

          <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                <ruby id="bdb3f"></ruby>

                合規國際互聯網加速 OSASE為企業客戶提供高速穩定SD-WAN國際加速解決方案。 廣告
                [TOC] ## http 形式訪問 <details> <summary>client.go</summary> ``` package main import ( "fmt" "github.com/opentracing/opentracing-go" "github.com/opentracing/opentracing-go/ext" "github.com/uber/jaeger-client-go/config" "github.com/uber/jaeger-client-go/log" "io" "net/http" ) func Init(service string) (opentracing.Tracer, io.Closer) { cfg := &config.Configuration{ ServiceName: service, Sampler: &config.SamplerConfig{ Type: "const", //全部采樣 Param: 1, //1 開啟全部采樣,0 關閉全部采樣,可通過 環境變量 JAEGER_SAMPLER_PARAM 控制 }, Reporter: &config.ReporterConfig{ LogSpans: true, //LocalAgentHostPort: "127.0.0.1:6831", }, } tracer, closer, err := cfg.NewTracer( config.Logger(log.StdLogger))//log.StdLogger 只要實現日志接口即可 if err != nil { panic(fmt.Sprintf("ERROR: cannot init Jaeger: %v\n", err)) } return tracer, closer } func main() { //初始化,只能在main 函數中初始化,因為需要 defer tracer, closer := Init("jaeger-demo11") defer closer.Close() //StartspanFromContext創建新span時會用到 opentracing.SetGlobalTracer(tracer) clientSpan := opentracing.StartSpan("parent2") defer clientSpan.Finish() url := "http://localhost:8082/publish" req, _ := http.NewRequest("GET", url, nil) ext.HTTPUrl.Set(clientSpan, url) ext.HTTPMethod.Set(clientSpan, "GET") // Inject the client span context into the headers tracer.Inject(clientSpan.Context(), opentracing.HTTPHeaders, opentracing.HTTPHeadersCarrier(req.Header)) resp, _ := http.DefaultClient.Do(req) fmt.Printf("%+v\n", resp.Header) } ``` </details> <br /> <details> <summary>server.go</summary> ``` package main import ( "github.com/opentracing/opentracing-go" "github.com/opentracing/opentracing-go/ext" "log" "net/http" ) func main() { tracer := opentracing.GlobalTracer() http.HandleFunc("/publish", func(w http.ResponseWriter, r *http.Request) { // 從標題中提取上下文 spanCtx, _ := tracer.Extract(opentracing.HTTPHeaders, opentracing.HTTPHeadersCarrier(r.Header)) serverSpan := tracer.StartSpan("server", ext.RPCServerOption(spanCtx)) defer serverSpan.Finish() }) log.Fatal(http.ListenAndServe(":8082", nil)) } ``` </details> <br /> ![7162E9CB-1465-4E0B-ABC7-7880A24F8157.png](http://yanxuan.nosdn.127.net/0b8614fa904d3ae7e5060323a70856ee.png)
                  <ruby id="bdb3f"></ruby>

                  <p id="bdb3f"><cite id="bdb3f"></cite></p>

                    <p id="bdb3f"><cite id="bdb3f"><th id="bdb3f"></th></cite></p><p id="bdb3f"></p>
                      <p id="bdb3f"><cite id="bdb3f"></cite></p>

                        <pre id="bdb3f"></pre>
                        <pre id="bdb3f"><del id="bdb3f"><thead id="bdb3f"></thead></del></pre>

                        <ruby id="bdb3f"><mark id="bdb3f"></mark></ruby><ruby id="bdb3f"></ruby>
                        <pre id="bdb3f"><pre id="bdb3f"><mark id="bdb3f"></mark></pre></pre><output id="bdb3f"></output><p id="bdb3f"></p><p id="bdb3f"></p>

                        <pre id="bdb3f"><del id="bdb3f"><progress id="bdb3f"></progress></del></pre>

                              <ruby id="bdb3f"></ruby>

                              哎呀哎呀视频在线观看