Go で http.Transport を使用して特定のリクエストに対する再試行メカニズムを実装するにはどうすればよいですか?
http.Transport を使用して Go で特定のリクエストの再試行メカニズムを実装するにはどうすればよいですか?
Web アプリケーションを開発する場合、ネットワーク リクエストが失敗することがよくあります。アプリケーションの堅牢性と安定性を向上させるために、特定のエラー コードが発生したときに自動的に再試行できます。 Go 言語では、http.Transport を通じて特定のリクエストの再試行メカニズムを実装できます。
まず、対応するパッケージをインポートする必要があります:
import ( "fmt" "net/http" "time" )
次に、カスタム トランスポートを作成し、その MaxIdleConnsPerHost
と MaxIdleConns
を設定する必要があります。接続を再利用するためのプロパティ:
transport := &http.Transport{ MaxIdleConnsPerHost: 10, MaxIdleConns: 100, }
次に、HTTP リクエストを送信し、再試行ロジックを処理する関数を定義できます。この関数では、http.Client
の Do メソッドを使用して HTTP リクエストを送信し、返されたエラー コードに基づいて再試行できます。
func sendRequestWithRetry(url string) (*http.Response, error) { client := &http.Client{ Transport: transport, } for i := 0; i < 3; i++ { // 最多重试3次 resp, err := client.Get(url) if err != nil { if isRetryableError(err) { fmt.Printf("请求失败,正在进行第 %d 次重试... ", i+1) time.Sleep(1 * time.Second) continue } return nil, err } if resp.StatusCode == http.StatusOK { return resp, nil } resp.Body.Close() if isRetryableStatusCode(resp.StatusCode) { fmt.Printf("请求失败,正在进行第 %d 次重试... ", i+1) time.Sleep(1 * time.Second) continue } return nil, fmt.Errorf("请求失败,错误码:%d", resp.StatusCode) } return nil, fmt.Errorf("重试次数已达到上限") }
再試行ロジックでは、次の 2 つを定義できます。補助関数 isRetryableError
および isRetryableStatusCode
は、再試行を実行する必要があるかどうかを決定するために使用されます。実際のニーズに応じて、どのエラー コードとステータス コードを再試行できるかを設定できます:
func isRetryableError(err error) bool { // 判断是否为连接错误等常见错误 // 可根据实际需求进行修改 if err == io.EOF || strings.Contains(err.Error(), "connection reset by peer") || strings.Contains(err.Error(), "no such host") { return true } return false } func isRetryableStatusCode(code int) bool { // 判断是否为可重试的HTTP状态码 // 可根据实际需求进行修改 if code >= 500 || code == http.StatusBadGateway || code == http.StatusServiceUnavailable { return true } return false }
最後に、上記の関数を使用して HTTP リクエストを送信し、再試行できます:
func main() { resp, err := sendRequestWithRetry("http://example.com") if err != nil { fmt.Println("请求失败:", err) } else { fmt.Println("请求成功:", resp.Status) resp.Body.Close() } }
上記のコード例 http.Transport を使用して、Go で特定のリクエストに対する再試行メカニズムを実装する方法を学びます。トランスポートをカスタマイズし、適切な再試行ロジックと組み合わせることで、アプリケーションがネットワーク要求の失敗をより適切に処理できるようになり、アプリケーションの信頼性と安定性が向上します。
以上がGo で http.Transport を使用して特定のリクエストに対する再試行メカニズムを実装するにはどうすればよいですか?の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

ホットAIツール

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

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

Undress AI Tool
脱衣画像を無料で

Clothoff.io
AI衣類リムーバー

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

人気の記事

ホットツール

メモ帳++7.3.1
使いやすく無料のコードエディター

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

ゼンドスタジオ 13.0.1
強力な PHP 統合開発環境

ドリームウィーバー CS6
ビジュアル Web 開発ツール

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

ホットトピック









Go では、関数のライフ サイクルには定義、ロード、リンク、初期化、呼び出し、戻り値が含まれます。変数のスコープは関数レベルとブロック レベルに分割されますが、ブロック内の変数はブロック内でのみ表示されます。 。

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

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

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

IDE を使用して Go 関数のドキュメントを表示する: 関数名の上にカーソルを置きます。ホットキーを押します (GoLand: Ctrl+Q; VSCode: GoExtensionPack をインストールした後、F1 キーを押して「Go:ShowDocumentation」を選択します)。

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

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