ホームページ バックエンド開発 Golang golang gin リクエスト統計

golang gin リクエスト統計

May 14, 2023 pm 05:20 PM

Web アプリケーションの開発に伴い、パフォーマンスとコードの最適化に対する要求がますます高まっています。この場合、リクエストの監視と統計が特に重要になります。この記事では、GolangとGinフレームワークを使用してリクエスト統計機能を実装する方法を紹介します。

背景

Web アプリケーションでは、次のような状況が発生すると、パフォーマンスの問題が発生する可能性があります。

  • 頻繁なデータベース クエリ
  • ネットワーク遅延が長すぎる
  • リクエスト タイムアウト
  • 同時リクエストが多すぎます

この場合、リクエストの統計と視覚的な表示は、問題を迅速に発見し、適切な措置を講じるのに役立ちます。

リクエストのカウント方法

まず、サーバーを通過するすべてのリクエスト情報を記録するミドルウェアを定義する必要があります。リクエストごとに、次の情報を記録する必要があります:

  • リクエスト パス
  • HTTP メソッド
  • リクエスト開始時間
  • リクエスト終了時間
  • リクエスト期間
  • リクエスト ステータス コード

Gin フレームワークを使用して、このミドルウェアを実行する関数を定義できます。まず、受信ハンドラーを実行してから、リクエスト情報をログに記録する必要があります。

func RequestStats() gin.HandlerFunc {
    return func(c *gin.Context) {
        t := time.Now()

        c.Next()

        latency := time.Since(t)

        status := c.Writer.Status()
        path := c.Request.URL.Path
        method := c.Request.Method

        log.Printf("[GIN] %s %s %d %v", method, path, status, latency)
    }
}
ログイン後にコピー

この関数では、log.Printf() 関数を使用してリクエスト情報を出力します。ここで、このミドルウェアを Jin エンジンに追加できます。

router := gin.Default()
router.Use(RequestStats())
ログイン後にコピー

このようにして、各リクエスト ミドルウェアが実行されるときにすべてのリクエスト情報を記録します。

視覚的なリクエスト統計

リクエスト統計をユーザーに表示するには、Web インターフェイスを使用できます。この場合、MVC (Model-View-Controller) デザイン パターンの使用が特に適しています。この場合、コントローラーはすべての Web リクエストを処理し、モデルからどのデータを取得するか、およびそれをどのように表示するかを決定する責任を負います。ビューはデータを表示する責任があります。

最初のステップは、コントローラーを定義することです。コントローラーは、ファイルに保存されているリクエスト統計を読み取り、レンダリングのためにビューに渡します。

func GetStats(c *gin.Context) {
    data, err := ioutil.ReadFile("stats.txt")
    if err != nil {
        c.String(http.StatusInternalServerError, fmt.Sprintf("Error reading file: %v", err))
        return
    }

    c.HTML(http.StatusOK, "stats.html", gin.H{
        "title": "Request Statistics",
        "data":  string(data),
    })
}
ログイン後にコピー

このコントローラー メソッドでは、最初にファイルからリクエスト統計を読み取ります。次に、データはレンダリングのために文字列としてテンプレート エンジンに渡されます。

次のステップはビューを定義することです。 HTML と CSS を使用して、美しいユーザー インターフェイスを作成できます。

<!DOCTYPE html>
<html>
    <head>
        <title>{{.title}}</title>
        <style>
            table {
                border-collapse: collapse;
                width: 100%;
            }

            th, td {
                text-align: left;
                padding: 8px;
            }

            th {
                background-color: #4CAF50;
                color: white;
            }

            tr:nth-child(even){background-color: #f2f2f2}
        </style>
    </head>
    <body>
        <h2>{{.title}}</h2>
        <table>
            <tr>
                <th>HTTP Method</th>
                <th>Request Path</th>
                <th>Status Code</th>
                <th>Latency</th>
            </tr>
            {{range split .data "
"}}
            {{with split . " "}}
            <tr>
                <td>{{index . 0}}</td>
                <td>{{index . 1}}</td>
                <td>{{index . 2}}</td>
                <td>{{index . 3}}</td>
            </tr>
            {{end}}
            {{end}}
        </table>
    </body>
</html>
ログイン後にコピー

このテンプレートでは、HTML と CSS を使用して、リクエスト データを表示するテーブルを作成します。

最後に、コントローラーをルートに関連付け、Gin エンジンに登録する必要があります。

router.GET("/stats", GetStats)
ログイン後にコピー

これで、リクエスト統計システムが完成し、Web ページを使用して表示できるようになりました。ユーザーに表示される統計結果。

結論

リクエスト統計は、HTTP メソッド、リクエスト パス、リクエスト ステータス コード、リクエスト期間などの情報を記録することで、Web アプリケーションを識別するのに役立つ重要な Web アプリケーション機能です。 一般的なパフォーマンスの問題。この記事では、Golang 言語と Jin フレームワークを使用してリクエスト統計を実装し、HTML と CSS を使用してデータを表示します。この実装は比較的シンプルで保守が容易で、Web アプリケーションの問題を迅速に特定するのに役立ちます。

以上がgolang gin リクエスト統計の詳細内容です。詳細については、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衣類リムーバー

Video Face Swap

Video Face Swap

完全無料の AI 顔交換ツールを使用して、あらゆるビデオの顔を簡単に交換できます。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

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

SublimeText3 中国語版

SublimeText3 中国語版

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

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

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

Debian OpenSSLの脆弱性は何ですか Debian OpenSSLの脆弱性は何ですか Apr 02, 2025 am 07:30 AM

OpenSSLは、安全な通信で広く使用されているオープンソースライブラリとして、暗号化アルゴリズム、キー、証明書管理機能を提供します。ただし、その歴史的バージョンにはいくつかの既知のセキュリティの脆弱性があり、その一部は非常に有害です。この記事では、Debian SystemsのOpenSSLの共通の脆弱性と対応測定に焦点を当てます。 Debianopensslの既知の脆弱性:OpenSSLは、次のようないくつかの深刻な脆弱性を経験しています。攻撃者は、この脆弱性を、暗号化キーなどを含む、サーバー上の不正な読み取りの敏感な情報に使用できます。

GOの浮動小数点番号操作に使用されるライブラリは何ですか? GOの浮動小数点番号操作に使用されるライブラリは何ですか? Apr 02, 2025 pm 02:06 PM

GO言語の浮動小数点数操作に使用されるライブラリは、精度を確保する方法を紹介します...

Go's Crawler Collyのキュースレッドの問題は何ですか? Go's Crawler Collyのキュースレッドの問題は何ですか? Apr 02, 2025 pm 02:09 PM

Go Crawler Collyのキュースレッドの問題は、Go言語でColly Crawler Libraryを使用する問題を調査します。 �...

フロントエンドからバックエンドの開発に変身すると、JavaやGolangを学ぶことはより有望ですか? フロントエンドからバックエンドの開発に変身すると、JavaやGolangを学ぶことはより有望ですか? Apr 02, 2025 am 09:12 AM

バックエンド学習パス:フロントエンドからバックエンドへの探査の旅は、フロントエンド開発から変わるバックエンド初心者として、すでにNodeJSの基盤を持っています...

Goでは、Printlnとstring()関数を備えた文字列を印刷すると、なぜ異なる効果があるのですか? Goでは、Printlnとstring()関数を備えた文字列を印刷すると、なぜ異なる効果があるのですか? Apr 02, 2025 pm 02:03 PM

Go言語での文字列印刷の違い:printlnとstring()関数を使用する効果の違いはGOにあります...

Debianの下のPostgreSQL監視方法 Debianの下のPostgreSQL監視方法 Apr 02, 2025 am 07:27 AM

この記事では、Debianシステムの下でPostgreSQLデータベースを監視するためのさまざまな方法とツールを紹介し、データベースのパフォーマンス監視を完全に把握するのに役立ちます。 1. PostgreSQLを使用して監視を監視す​​るビューPostgreSQL自体は、データベースアクティビティを監視するための複数のビューを提供します。 PG_STAT_REPLICATION:特にストリームレプリケーションクラスターに適した複製ステータスを監視します。 PG_STAT_DATABASE:データベースサイズ、トランザクションコミット/ロールバック時間、その他のキーインジケーターなどのデータベース統計を提供します。 2。ログ分析ツールPGBADGを使用します

Beego ormのモデルに関連付けられているデータベースを指定する方法は? Beego ormのモデルに関連付けられているデータベースを指定する方法は? Apr 02, 2025 pm 03:54 PM

Beegoormフレームワークでは、モデルに関連付けられているデータベースを指定する方法は?多くのBEEGOプロジェクトでは、複数のデータベースを同時に操作する必要があります。 Beegoを使用する場合...

Redisストリームを使用してGO言語でメッセージキューを実装する場合、user_idタイプの変換の問題を解決する方法は? Redisストリームを使用してGO言語でメッセージキューを実装する場合、user_idタイプの変換の問題を解決する方法は? Apr 02, 2025 pm 04:54 PM

redisstreamを使用してGo言語でメッセージキューを実装する問題は、GO言語とRedisを使用することです...

See all articles