Go: ResponseController の期限が守られない
phpエディタのいちごが「Go: ResponseControllerの期限を守らない」について紹介します。ソフトウェア開発では、ResponseController は応答要求を処理するために使用される一般的なコントローラーです。ただし、開発者がコードを記述するときに ResponseController の期限を遵守しない場合があり、これにより一連の問題が発生する可能性があります。この記事では、この問題を詳しく調査し、コードの信頼性と安定性を確保するための解決策を提供します。
質問内容
書き込みに時間がかかりすぎる場合に、クライアントへの書き込みをキャンセルしようとするコードがいくつかあります。 http.responsecontroller には setwritedeadline メソッドがあるので、これを使用できると思います。
残念ながら、以下のコードでは、rw.write
は期限が過ぎてもエラーを返しません。
書き込みをキャンセルする他の方法はありますか?
リーリー リーリーpackage main import ( "log" "net/http" "time" ) func main() { http.handlefunc("/", func(rw http.responsewriter, r *http.request) { log.println(r.method, r.url.path) rc := http.newresponsecontroller(rw) dl := time.now().add(3 * time.second) if err := rc.setwritedeadline(dl); err != nil { log.println(err) return } log.println("write deadline:", dl) var total int for _, b := range []byte("what!\n") { time.sleep(time.second) n, err := rw.write([]byte{b}) if err != nil { log.println(err) return } total += n log.println("bytes written", n) } log.println(r.method, r.url.path, "write total", total) }) http.listenandserve(":8080", nil) }
ソリューション
setwritedeadline 応答を書く期限を設定します。期限が過ぎた後の応答本文の書き込みはブロックされませんが、データがバッファリングされている場合は成功する可能性があります。
アプリケーションによって書き込まれた少量のデータがバッファリングされるため、質問内の応答ライターへの書き込みは成功します。
カールからの「サーバーからの空の応答」エラーは、サーバーがハンドラーから戻ったときに基礎となるネットワーク接続への応答をフラッシュするときに期限が遵守されることを示します。
setwritedeadline を使用して、クライアントの速度低下を防ぎます。
期限付きのコンテキストを使用して、サーバーが応答を生成するのにかかる時間を制限します: 65bd46fc4 2月
以上がGo: ResponseController の期限が守られないの詳細内容です。詳細については、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)

ホットトピック

この記事では、プロファイリングの有効化、データの収集、CPUやメモリの問題などの一般的なボトルネックの識別など、GOパフォーマンスを分析するためにPPROFツールを使用する方法について説明します。

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

この記事では、GOでユニットテストを書くことで、ベストプラクティス、モッキングテクニック、効率的なテスト管理のためのツールについて説明します。

この記事では、ユニットテストのためにGOのモックとスタブを作成することを示しています。 インターフェイスの使用を強調し、模擬実装の例を提供し、模擬フォーカスを維持し、アサーションライブラリを使用するなどのベストプラクティスについて説明します。 articl

この記事では、GENICSのGOのカスタムタイプの制約について説明します。 インターフェイスがジェネリック関数の最小タイプ要件をどのように定義するかを詳しく説明し、タイプの安全性とコードの再利用性を改善します。 この記事では、制限とベストプラクティスについても説明しています

この記事では、コードのランタイム操作に使用されるGoの反射パッケージについて説明します。シリアル化、一般的なプログラミングなどに有益です。実行やメモリの使用量の増加、賢明な使用と最高のアドバイスなどのパフォーマンスコストについて警告します

この記事では、トレースツールを使用してGOアプリケーションの実行フローを分析します。 手動および自動計装技術について説明し、Jaeger、Zipkin、Opentelemetryなどのツールを比較し、効果的なデータの視覚化を強調しています

この記事では、GOでテーブル駆動型のテストを使用して説明します。これは、テストのテーブルを使用して複数の入力と結果を持つ関数をテストする方法です。読みやすさの向上、重複の減少、スケーラビリティ、一貫性、および
