欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

golang使用jaeger進(jìn)行鏈路追蹤

 更新時間:2024年06月12日 10:03:17   作者:dearlin2024  
鏈路追蹤是指在分布式系統(tǒng)中,將一次請求的處理過程進(jìn)行記錄并聚合展示的一種方法,目的是將一次分布式請求的調(diào)用情況集中在一處展示,本文將介紹golang如何使用jaeger進(jìn)行鏈路追蹤,需要的朋友可以參考下

前言

提示:請配置好環(huán)境

一、什么是鏈路追蹤?

鏈路追蹤是指在分布式系統(tǒng)中,將一次請求的處理過程進(jìn)行記錄并聚合展示的一種方法。目的是將一次分布式請求的調(diào)用情況集中在一處展示,如各個服務(wù)節(jié)點(diǎn)上的耗時、請求具體到達(dá)哪臺機(jī)器上、每個服務(wù)節(jié)點(diǎn)的請求狀態(tài)等。這樣就可以輕松了解一個請求在系統(tǒng)中的完整生命周期,包括經(jīng)過的服務(wù)、調(diào)用的操作以及每個操作的延遲等。通過鏈路追蹤,可以更好地理解系統(tǒng)的性能瓶頸、找出問題的根源以及優(yōu)化系統(tǒng)的性能。

二、安裝jaeger

docker pull jaegertracing/all-in-one:latest
docker run -d --name myjaeger -p 6831:6831/udp -p 16686:16686 jaegertracing/all-in-one:latest

運(yùn)行:127.0.0.1:16686

在這里插入圖片描述

三、golang使用jaeger進(jìn)行鏈路追蹤

github地址

package main

import (
	"time"

	opentracing "github.com/opentracing/opentracing-go"
	"github.com/uber/jaeger-client-go"
	jaegercfg "github.com/uber/jaeger-client-go/config"
	jaegerlog "github.com/uber/jaeger-client-go/log"
)

func main() {
	cfg := jaegercfg.Configuration{
		Sampler: &jaegercfg.SamplerConfig{
			Type:  jaeger.SamplerTypeConst,
			Param: 1,
		},
		Reporter: &jaegercfg.ReporterConfig{
			LogSpans:           true,
			LocalAgentHostPort: "127.0.0.1:6831",
		},
		ServiceName: "deardai-shop",
	}
	tracer, closer, err := cfg.NewTracer(jaegercfg.Logger(jaegerlog.StdLogger))
	if err != nil {
		panic(err)
	}
	defer closer.Close()

	//單個追蹤
	single_span := tracer.StartSpan("single-span")
	time.Sleep(time.Second * 3)
	single_span.Finish()

	//父子追蹤

	parentSpan := tracer.StartSpan("main")

	span := tracer.StartSpan("func1", opentracing.ChildOf(parentSpan.Context()))
	time.Sleep(time.Second)
	span.Finish()
	span2 := tracer.StartSpan("func2", opentracing.ChildOf(span.Context()))
	time.Sleep(time.Second * 3)
	span2.Finish()

	parentSpan.Finish()
}

結(jié)果:

可以看到下圖展示出了兩個鏈路

在這里插入圖片描述

2. 單個方法的追蹤

在這里插入圖片描述

多個方法的組合

在這里插入圖片描述

總結(jié)

到此這篇關(guān)于golang使用jaeger進(jìn)行鏈路追蹤的文章就介紹到這了,更多相關(guān)golang jaeger鏈路追蹤內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Golang之sync.Pool使用詳解

    Golang之sync.Pool使用詳解

    這篇文章主要介紹了Golang之sync.Pool使用詳解,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2021-05-05
  • golang如何去除 context 的 deadline

    golang如何去除 context 的 deadline

    在使用 context 的時候遇到了開協(xié)程處理任務(wù)的情況,但是直接在協(xié)程里使用主線程的 context 會導(dǎo)致當(dāng)主線程返回時協(xié)程任務(wù)也會因?yàn)?nbsp;context cancel 而失敗,本文提供了兩種辦法可以取消掉 context 里的 timeout 和 deadline,再設(shè)置一個新的 timeout 上去
    2023-03-03
  • 從生成CRD到編寫自定義控制器教程示例

    從生成CRD到編寫自定義控制器教程示例

    這篇文章主要為大家介紹了從生成CRD到編寫自定義控制器的教程示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-05-05
  • 基于Go語言實(shí)現(xiàn)猜謎游戲

    基于Go語言實(shí)現(xiàn)猜謎游戲

    這篇文章主要為大家詳細(xì)介紹了如何基于Go語言實(shí)現(xiàn)猜謎游戲,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)
    2023-09-09
  • Golang 拷貝Array或Slice的操作

    Golang 拷貝Array或Slice的操作

    這篇文章主要介紹了Golang 拷貝Array或Slice的操作,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2021-04-04
  • golang實(shí)現(xiàn)redis的延時消息隊(duì)列功能示例

    golang實(shí)現(xiàn)redis的延時消息隊(duì)列功能示例

    這篇文章主要介紹了golang實(shí)現(xiàn)redis的延時消息隊(duì)列功能,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-11-11
  • GoLang完整實(shí)現(xiàn)快速列表

    GoLang完整實(shí)現(xiàn)快速列表

    這篇文章主要介紹了GoLang完整實(shí)現(xiàn)快速列表,列表是一種非連續(xù)的存儲容器,由多個節(jié)點(diǎn)組成,節(jié)點(diǎn)通過一些 變量 記錄彼此之間的關(guān)系,列表有多種實(shí)現(xiàn)方法,如單鏈表、雙鏈表等
    2022-12-12
  • Go使用sync.Map來解決map的并發(fā)操作問題

    Go使用sync.Map來解決map的并發(fā)操作問題

    在 Golang 中 map 不是并發(fā)安全的,sync.Map 的引入確實(shí)解決了 map 的并發(fā)安全問題,本文就詳細(xì)的介紹一下如何使用,感興趣的可以了解一下
    2021-10-10
  • go語言interface接口繼承多態(tài)示例及定義解析

    go語言interface接口繼承多態(tài)示例及定義解析

    這篇文章主要為大家介紹了go語言interface接口繼承多態(tài)示例及定義解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步早日升職加薪
    2022-04-04
  • Golang中大端序和小端序的處理

    Golang中大端序和小端序的處理

    大端序和小端序是描述多字節(jié)數(shù)據(jù)在內(nèi)存中存儲順序的術(shù)語,本文主要介紹了Golang中大端序和小端序的處理,具有一定的參考價值,感興趣的可以了解一下
    2025-02-02

最新評論