ホームページ バックエンド開発 Golang Zipkin と Yeter を使用して Beego に分散トレーシングを実装する

Zipkin と Yeter を使用して Beego に分散トレーシングを実装する

Jun 22, 2023 pm 03:22 PM
beego zipkin jaeger

Zipkin と Yeter を使用して Beego に分散トレーシングを実装する

マイクロサービスの人気に伴い、分散システムの開発はますます一般的になってきました。ただし、分散システムは、さまざまなサービス間のリクエストのフローを追跡する方法、サービスのパフォーマンスを分析して最適化する方法など、新たな課題ももたらします。これらの点で、分散トレーシング ソリューションはますます重要なコンポーネントになっています。この記事では、Zipkin と Yeter を使用して Beego に分散トレーシングを実装する方法を紹介します。

複数のサービスにわたるリクエストのトレースは、分散トレースの主な目的です。一元化されたログ ストリームやメトリック ストリームでは、サービス間の相関関係を提供できないため、この問題を解決できません。リクエストには複数のサービスの連携が必要な場合があり、これらのサービスは他のサービスの応答時間と動作を認識している必要があります。従来のアプローチでは、さまざまなメトリクスをログに記録し、しきい値を緩和してリクエスト受信時のブロックを回避します。ただし、このアプローチでは、不具合やパフォーマンスの問題などの問題が隠れてしまう可能性があります。分散トレーシングは、サービス間のリクエスト トレースのソリューションです。このアプローチでは、リクエストがサービス間を流れるとき、各サービスはリクエスト全体を追跡する一連の ID を生成します。

Beego で分散トレーシングを実装する方法を見てみましょう。

Zipkin と Yeter は、現在最も人気のある分散トレース ソリューションです。どちらのツールも OpenTracing API をサポートしているため、開発者はサービス全体で一貫した方法でリクエストをログに記録し、追跡することができます。

まず、Zipkin または Yeter をインストールして起動し、Beego アプリケーションで分散トレーシングを構成する必要があります。この記事ではZipkinを使用します。

Zipkin をインストールします:

curl -sSL https://zipkin.io/quickstart.sh | bash -s
java -jar zipkin.jar
ログイン後にコピー

Zipkin が起動すると、http://localhost:9411 経由で Web UI にアクセスできます。

次に、Beego に OpenTracing API のサポートを追加する必要があります。 opentracing-go パッケージを使用し、それが提供する API を使用してサービス間のリクエストやその他のイベントをログに記録できます。トラッキング コードの例は次のとおりです。

import (
    "github.com/opentracing/opentracing-go"
)

func main() {
    // Initialize the tracer
    tracer, closer := initTracer()
    defer closer.Close()

    // Start a new span
    span := tracer.StartSpan("example-span")

    // Record some events
    span.SetTag("example-tag", "example-value")
    span.LogKV("example-key", "example-value")

    // Finish the span
    span.Finish()
}

func initTracer() (opentracing.Tracer, io.Closer) {
    // Initialize the tracer
    tracer, closer := zipkin.NewTracer(
        zipkin.NewReporter(httpTransport.NewReporter("http://localhost:9411/api/v2/spans")),
        zipkin.WithLocalEndpoint(zipkin.NewEndpoint("example-service", "localhost:80")),
        zipkin.WithTraceID128Bit(true),
    )

    // Set the tracer as the global tracer
    opentracing.SetGlobalTracer(tracer)

    return tracer, closer
}
ログイン後にコピー

上記の例では、最初に Zipkin トラッカーを初期化し、それを使用していくつかのイベントを記録します。タグとキーと値のペアを追加し、span.Finish() を呼び出すことでスパンを終了できます。

次に、分散トレーシングを Beego アプリケーションに追加しましょう。

まず、opentracing-go と zipkin-go-opentracing の依存関係を追加しましょう。これは、go mod を使用するか、手動でパッケージをインストールすることで実行できます。

go get github.com/opentracing/opentracing-go
go get github.com/openzipkin/zipkin-go-opentracing
ログイン後にコピー

次に、Beego アプリケーションで Zipkin トラッカーと Beego トラッカー ミドルウェアを初期化する必要があります。以下は、Beego トレーサー ミドルウェアのサンプル コードです。

import (
    "net/http"

    "github.com/astaxie/beego"
    opentracing "github.com/opentracing/opentracing-go"
    "github.com/openzipkin/zipkin-go-opentracing"
)

func TraceMiddleware() func(http.ResponseWriter, *http.Request, http.HandlerFunc) {
    return func(w http.ResponseWriter, r *http.Request, next http.HandlerFunc) {
        // Initialize the tracer
        tracer, closer := initTracer()
        defer closer.Close()

        // Extract the span context from the HTTP headers
        spanCtx, err := tracer.Extract(opentracing.HTTPHeaders,
            opentracing.HTTPHeadersCarrier(r.Header))
        if err != nil && err != opentracing.ErrSpanContextNotFound {
            beego.Error("failed to extract span context:", err)
        }

        // Start a new span
        span := tracer.StartSpan(r.URL.Path, ext.RPCServerOption(spanCtx))

        // Set some tags
        span.SetTag("http.method", r.Method)
        span.SetTag("http.url", r.URL.String())

        // Inject the span context into the HTTP headers
        carrier := opentracing.HTTPHeadersCarrier(r.Header)
        if err := tracer.Inject(span.Context(),
            opentracing.HTTPHeaders, carrier); err != nil {
            beego.Error("failed to inject span context:", err)
        }

        // Set the span as a variable in the request context
        r = r.WithContext(opentracing.ContextWithSpan(r.Context(), span))

        // Call the next middleware/handler
        next(w, r)

        // Finish the span
        span.Finish()
    }
}

func initTracer() (opentracing.Tracer, io.Closer) {
    // Initialize the Zipkin tracer
    report := zipkinhttp.NewReporter("http://localhost:9411/api/v2/spans")
    defer report.Close()

    endpoint, err := zipkin.NewEndpoint("example-service", "localhost:80")
    if err != nil {
        beego.Error("failed to create Zipkin endpoint:", err)
    }

    nativeTracer, err := zipkin.NewTracer(
        report, zipkin.WithLocalEndpoint(endpoint),
        zipkin.WithTraceID128Bit(true))
    if err != nil {
        beego.Error("failed to create Zipkin tracer:", err)
    }

    // Initialize the OpenTracing API tracer
    tracer := zipkinopentracing.Wrap(nativeTracer)

    // Set the tracer as the global tracer
    opentracing.SetGlobalTracer(tracer)

    return tracer, report
}
ログイン後にコピー

上記のサンプル コードでは、TraceMiddleware という名前のミドルウェアを定義します。このミドルウェアは、HTTP ヘッダー (存在する場合) から既存の追跡コンテキストを抽出し、それを使用してリクエストの新しいトラッカーを作成します。また、他のすべてのミドルウェアとハ​​ンドラーがそれにアクセスできるように、リクエスト コンテキストでスパンを設定します。最後に、ハンドラーの実行が終了した後、スパンでfinish() メソッドを呼び出します。これにより、Zipkin は、要求されたすべてのサービスにわたる相互依存関係の追跡を記録できるようになります。

このミドルウェアを Beego ルーターに接続する必要もあります。これは、ルーターの初期化コードで次のコードを使用して実行できます。

beego.InsertFilter("*", beego.BeforeRouter, TraceMiddleware())
ログイン後にコピー

ここで、Beego アプリケーションを起動し、http://localhost:9411 にアクセスして Zipkin UI を開いて追跡データを表示します。

Beego アプリケーションに分散トレーシングを実装するのは複雑に思えるかもしれませんが、opentracing-go ライブラリと zipkin-go-opentracing ライブラリを使用することで、この機能を簡単に追加できます。これは、サービスの数と複雑さが増加し続けるにつれてますます重要になり、サービスがどのように連携して機能するかを理解し、リクエスト処理プロセス全体で適切に動作することを保証できるようになります。

以上がZipkin と Yeter を使用して Beego に分散トレーシングを実装するの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

Prometheus と Grafana を使用して Beego で監視と警報を実装する Prometheus と Grafana を使用して Beego で監視と警報を実装する Jun 22, 2023 am 09:06 AM

クラウド コンピューティングとマイクロサービスの台頭により、アプリケーションの複雑さは増大しています。したがって、監視と診断は重要な開発タスクの 1 つになります。この点に関して、Prometheus と Grafana は、開発者がアプリケーションをより適切に監視および分析できるようにする 2 つの人気のあるオープンソース監視および視覚化ツールです。この記事では、Prometheus と Grafana を使用して、Beego フレームワークに監視と警報を実装する方法を説明します。 1. はじめに Beego は、オープンソースの高速開発 Web アプリケーションです。

Google Analytics を使用して Beego の Web サイトデータをカウントする Google Analytics を使用して Beego の Web サイトデータをカウントする Jun 22, 2023 am 09:19 AM

インターネットの急速な発展に伴い、Web アプリケーションの使用がますます一般的になり、Web アプリケーションの使用状況をどのように監視および分析するかが開発者や Web サイト運営者の焦点になっています。 Google Analytics は、Web サイト訪問者の行動を追跡および分析できる強力な Web サイト分析ツールです。この記事では、Beego で Google Analytics を使用して Web サイトのデータを収集する方法を紹介します。 1. Google Analytics アカウントを登録するには、まず次のことを行う必要があります。

Beego でのエラー処理 - アプリケーションのクラッシュを防ぐ Beego でのエラー処理 - アプリケーションのクラッシュを防ぐ Jun 22, 2023 am 11:50 AM

Beego フレームワークでは、エラー処理は非常に重要な部分です。アプリケーションに正しく完全なエラー処理メカニズムが備わっていないと、アプリケーションがクラッシュしたり、正しく実行されなくなる可能性があり、これはプロジェクトとユーザーの両方にとって重要です。非常に深刻な問題。 Beego フレームワークは、これらの問題を回避し、コードをより堅牢で保守しやすくするのに役立つ一連のメカニズムを提供します。この記事では、Beego フレームワークのエラー処理メカニズムを紹介し、それらがエラーの回避にどのように役立つかについて説明します。

テクノロジーの世界を探索できる、厳選された 5 つの Go 言語オープンソース プロジェクト テクノロジーの世界を探索できる、厳選された 5 つの Go 言語オープンソース プロジェクト Jan 30, 2024 am 09:08 AM

今日の急速な技術発展の時代では、雨後の筍のようにプログラミング言語が出現しています。多くの注目を集めている言語の 1 つは Go 言語です。Go 言語は、そのシンプルさ、効率性、同時実行の安全性などの機能により多くの開発者に愛されています。 Go 言語は、多くの優れたオープンソース プロジェクトがある強力なエコシステムで知られています。この記事では、厳選された 5 つの Go 言語オープンソース プロジェクトを紹介し、読者を Go 言語オープンソース プロジェクトの世界へ導きます。 KubernetesKubernetes は、自動化されたオープンソースのコンテナ オーケストレーション エンジンです。

Beego での分散調整と管理のための ZooKeeper と Curator の使用 Beego での分散調整と管理のための ZooKeeper と Curator の使用 Jun 22, 2023 pm 09:27 PM

インターネットの急速な発展に伴い、分散システムは多くの企業や組織のインフラストラクチャの 1 つになりました。分散システムが適切に機能するには、調整して管理する必要があります。この点で、ZooKeeper と Curator は使用する価値のある 2 つのツールです。 ZooKeeper は、クラスター内のノード間のステータスとデータを調整するのに役立つ、非常に人気のある分散調整サービスです。 Curator は ZooKeeper のカプセル化です

Beego の Docker と Kubernetes を使用した本番環境のデプロイと管理 Beego の Docker と Kubernetes を使用した本番環境のデプロイと管理 Jun 23, 2023 am 08:58 AM

インターネットの急速な発展に伴い、ますます多くの企業がアプリケーションをクラウド プラットフォームに移行し始めています。 Docker と Kubernetes は、クラウド プラットフォームでのアプリケーションの展開と管理のための 2 つの非常に人気のある強力なツールになりました。 BeegoはGolangで開発されたWebフレームワークで、HTTPルーティング、MVC階層化、ロギング、構成管理、セッション管理などの豊富な機能を提供します。この記事では、Docker と Kub の使用方法について説明します。

Go 言語開発の要点: 5 つの人気のあるフレームワークの推奨事項 Go 言語開発の要点: 5 つの人気のあるフレームワークの推奨事項 Mar 24, 2024 pm 01:15 PM

「Go 言語開発の要点: 5 つの人気フレームワークの推奨事項」 高速で効率的なプログラミング言語として、Go 言語はますます多くの開発者に好まれています。開発効率を向上させ、コード構造を最適化するために、多くの開発者はフレームワークを使用してアプリケーションを迅速に構築することを選択します。 Go 言語の世界には、選択できる優れたフレームワークが数多くあります。この記事では、5 つの人気のある Go 言語フレームワークを紹介し、読者がこれらのフレームワークをよりよく理解して使用できるように、具体的なコード例を示します。 1.GinGin は高速な軽量 Web フレームワークです。

JWT を使用して Beego に認証を実装する JWT を使用して Beego に認証を実装する Jun 22, 2023 pm 12:44 PM

インターネットやモバイルインターネットの急速な発展に伴い、認証や権限制御を必要とするアプリケーションが増えており、軽量な認証・認可機構としてJWT(JSON Web Token)がWEBアプリケーションで広く使われています。 Beego は Go 言語をベースにした MVC フレームワークであり、効率性、シンプルさ、スケーラビリティの利点を備えています。この記事では、Beego で JWT を使用して認証を実装する方法を紹介します。 1. JWT の概要 JSONWebToken (JWT) は

See all articles