ホームページ バックエンド開発 Golang Go と http.Transport を使用して HTTP リクエストのログを実装するにはどうすればよいですか?

Go と http.Transport を使用して HTTP リクエストのログを実装するにはどうすればよいですか?

Jul 23, 2023 am 11:22 AM
go ロギング httptransport

Go と http.Transport を使用して HTTP リクエストのログを実装するにはどうすればよいですか?

Go 言語を使用して HTTP リクエストを行う場合、リクエストの URL、リクエスト メソッド、リクエスト ヘッダー、リクエスト本文などを記録するなど、リクエストの詳細情報を記録する必要がある状況がよく発生します。この情報は、問題のデバッグやトラブルシューティングに非常に役立ちます。この記事では、Go と http.Transport を使用して HTTP リクエストのログを実装する方法を紹介します。

Go 言語では、http パッケージを使用して HTTP リクエストを作成でき、http.Transport は HTTP リクエストと応答の送受信を担当します。 http.Transport の RoundTrip メソッドをカスタマイズすることで、リクエストの送信前とレスポンスの受信後にリクエスト ログを記録できます。

以下はサンプル コードです:

package main

import (
    "log"
    "net/http"
    "net/http/httputil"
    "os"
    "time"
)

// LoggingTransport 实现了http.RoundTripper接口
type LoggingTransport struct {
    Transport http.RoundTripper
    Logger    *log.Logger
}

// RoundTrip 实现了http.RoundTripper接口的RoundTrip方法
func (t *LoggingTransport) RoundTrip(req *http.Request) (*http.Response, error) {
    startTime := time.Now()

    // 打印请求信息
    dump, err := httputil.DumpRequestOut(req, true)
    if err != nil {
        return nil, err
    }
    t.Logger.Println(string(dump))

    // 发送请求
    resp, err := t.Transport.RoundTrip(req)
    if err != nil {
        return nil, err
    }

    // 打印响应信息
    dump, err = httputil.DumpResponse(resp, true)
    if err != nil {
        return nil, err
    }
    t.Logger.Println(string(dump))

    // 计算请求耗时并打印
    duration := time.Since(startTime)
    t.Logger.Printf("Request took %s", duration)

    return resp, nil
}

func main() {
    // 创建自定义Transport
    transport := &LoggingTransport{
        Transport: http.DefaultTransport,
        Logger:    log.New(os.Stdout, "", log.LstdFlags),
    }

    // 创建自定义的http.Client
    client := &http.Client{
        Transport: transport,
    }

    // 创建自定义的http.Request
    req, err := http.NewRequest("GET", "http://www.example.com", nil)
    if err != nil {
        log.Fatal(err)
    }

    // 发送请求
    resp, err := client.Do(req)
    if err != nil {
        log.Fatal(err)
    }
    defer resp.Body.Close()

    // 处理响应
    // ...

}
ログイン後にコピー

上記のコードでは、まず http.RoundTripper インターフェイスの RoundTrip メソッドを実装する LoggingTransport タイプを定義します。このメソッドでは、まずリクエストの開始時刻として現在時刻を取得し、次に httputil パッケージの DumpRequestOut メソッドを使用してリクエスト情報をバイト配列に変換してログ ファイルに書き込み、リクエストを送信してから、 DumpResponse メソッドを使用して応答情報を次の形式に変換します。バイト配列がログ ファイルに書き込まれ、最後に要求時間が計算されて出力されます。

メイン関数では、カスタムのトランスポートとクライアントを作成し、それらを http.Client の Transport フィールドと http.NewRequest 関数の最後のパラメータにそれぞれ渡し、リクエストを送信して応答を処理します。 。

このようにして、HTTP リクエストのログを簡単に実装できます。実際のニーズに応じて、ログ情報をコンソールに出力したり、ファイルに書き込んだり、ログ収集システムに送信したりできます。

概要: この記事では、Go と http.Transport を使用して HTTP リクエストのログを実装する方法を紹介します。 http.Transport の RoundTrip メソッドをカスタマイズして、デバッグとトラブルシューティングを容易にするために、リクエストの送信前と応答の受信後にリクエストの詳細を記録します。この記事がお役に立てば幸いです!

以上がGo と http.Transport を使用して HTTP リクエストのログを実装するにはどうすればよいですか?の詳細内容です。詳細については、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)

Go で正規表現を使用してタイムスタンプを照合するにはどうすればよいですか? Go で正規表現を使用してタイムスタンプを照合するにはどうすればよいですか? Jun 02, 2024 am 09:00 AM

Go では、正規表現を使用してタイムスタンプを照合できます。ISO8601 タイムスタンプの照合に使用されるような正規表現文字列をコンパイルします。 ^\d{4}-\d{2}-\d{2}T \d{ 2}:\d{2}:\d{2}(\.\d+)?(Z|[+-][0-9]{2}:[0-9]{2})$ 。 regexp.MatchString 関数を使用して、文字列が正規表現と一致するかどうかを確認します。

Go WebSocket メッセージを送信するにはどうすればよいですか? Go WebSocket メッセージを送信するにはどうすればよいですか? Jun 03, 2024 pm 04:53 PM

Go では、gorilla/websocket パッケージを使用して WebSocket メッセージを送信できます。具体的な手順: WebSocket 接続を確立します。テキスト メッセージを送信します。 WriteMessage(websocket.TextMessage,[]byte("message")) を呼び出します。バイナリ メッセージを送信します。WriteMessage(websocket.BinaryMessage,[]byte{1,2,3}) を呼び出します。

GolangとGo言語の違い GolangとGo言語の違い May 31, 2024 pm 08:10 PM

Go と Go 言語は、異なる特性を持つ別個の存在です。 Go (Golang とも呼ばれます) は、同時実行性、高速なコンパイル速度、メモリ管理、およびクロスプラットフォームの利点で知られています。 Go 言語の欠点としては、他の言語に比べてエコシステムが充実していないこと、構文が厳格であること、動的型付けが欠如していることが挙げられます。

C++ クラス設計でエラー処理とログ記録を実行するにはどうすればよいですか? C++ クラス設計でエラー処理とログ記録を実行するにはどうすればよいですか? Jun 02, 2024 am 09:45 AM

C++ クラス設計におけるエラー処理とログ記録には、次のものが含まれます。 例外処理: カスタム例外クラスを使用して例外をキャッチして処理し、特定のエラー情報を提供します。エラー コード: 整数または列挙を使用してエラー状態を表し、戻り値で返します。アサーション: 事前条件と事後条件を確認し、条件が満たされない場合は例外をスローします。 C++ ライブラリのロギング: std::cerr および std::clog を使用した基本的なロギング。外部ログ ライブラリ: レベル フィルタリングやログ ファイル ローテーションなどの高度な機能を提供するサードパーティ ライブラリを統合します。カスタム ログ クラス: 独自のログ クラスを作成し、基礎となるメカニズムを抽象化し、さまざまなレベルの情報を記録するための共通インターフェイスを提供します。

PHP Web サイト用のカスタム ログ ソリューションを作成する方法 PHP Web サイト用のカスタム ログ ソリューションを作成する方法 May 03, 2024 am 08:48 AM

PHP Web サイト用のカスタム ログ ソリューションを作成するには、PSR-3 互換ライブラリ (Monolog、Log4php、PSR-3Logger など) を使用する方法、または PHP ネイティブ ログ関数 (error_log()、syslog( など) を使用する方法など、いくつかの方法があります。 )、debug_print_backtrace())。アプリケーションの動作の監視と問題のトラブルシューティングは、カスタム ログ ソリューションを使用して簡単に行うことができます。たとえば、Monolog を使用して、メッセージをディスク ファイルに記録するロガーを作成します。

Golang の技術的なパフォーマンスの最適化でメモリ リークを回避するにはどうすればよいですか? Golang の技術的なパフォーマンスの最適化でメモリ リークを回避するにはどうすればよいですか? Jun 04, 2024 pm 12:27 PM

メモリ リークは、ファイル、ネットワーク接続、データベース接続などの使用されなくなったリソースを閉じることによって、Go プログラムのメモリを継続的に増加させる可能性があります。弱参照を使用してメモリ リークを防ぎ、強参照されなくなったオブジェクトをガベージ コレクションの対象にします。 go coroutine を使用すると、メモリ リークを避けるために、終了時にコルーチンのスタック メモリが自動的に解放されます。

Golang のエラー ラッパーを使用するにはどうすればよいですか? Golang のエラー ラッパーを使用するにはどうすればよいですか? Jun 03, 2024 pm 04:08 PM

Golang では、エラー ラッパーを使用して、元のエラーにコンテキスト情報を追加することで新しいエラーを作成できます。これを使用すると、さまざまなライブラリまたはコンポーネントによってスローされるエラーの種類を統一し、デバッグとエラー処理を簡素化できます。手順は次のとおりです。errors.Wrap 関数を使用して、元のエラーを新しいエラーにラップします。新しいエラーには、元のエラーのコンテキスト情報が含まれています。 fmt.Printf を使用してラップされたエラーを出力し、より多くのコンテキストとアクション性を提供します。異なる種類のエラーを処理する場合は、errors.Wrap 関数を使用してエラーの種類を統一します。

Go 同時関数の単体テストのガイド Go 同時関数の単体テストのガイド May 03, 2024 am 10:54 AM

並行関数の単体テストは、同時環境での正しい動作を確認するのに役立つため、非常に重要です。同時実行機能をテストするときは、相互排他、同期、分離などの基本原則を考慮する必要があります。並行機能は、シミュレーション、競合状態のテスト、および結果の検証によって単体テストできます。

See all articles