目次
質問の内容
回避策
ホームページ バックエンド開発 Golang Go でマルチスレッドリクエストが発生し、高い RPS が得られない

Go でマルチスレッドリクエストが発生し、高い RPS が得られない

Feb 09, 2024 pm 04:48 PM
言語を移動

go 中的多线程请求并且没有获得高 RPS

php エディターの Xigua は、Go 言語を使用してマルチスレッド リクエストを行う場合、高い RPS (Request Per Second) 速度を実現できない場合があることに気付きました。 Go 言語は同時処理に優れていますが、場合によっては、マルチスレッドのリクエストがあまり効率的ではありません。これは、ネットワーク遅延、リソースの競合などが原因である可能性があります。この記事では、この問題を調査し、Go 言語でのマルチスレッド リクエストの RPS を向上させるために考えられる解決策をいくつか紹介します。

質問の内容

サーバーをテストするためにマルチスレッド クライアントを作成しようとしています。 2 つのゴルーチンを使用すると、すべて問題なく、50,000 RPS が得られ、CPU 負荷は正常ですが、2 つを超えるゴルーチンを作成すると、RPS は 3,000 に低下しますが、CPU 負荷が超過します。ただし、クライアント コードを複数回実行すると (同じコードを 3 台のコンソールで同時に実行するなど)、80,000 RPS ほどの RPS が得られます。

これは私のクライアントコードです

リーリー

これは私のサーバー側のコードです

リーリー

最初、go はすべてのクライアント接続に 1 つのポートを使用しているのではないかと思いましたが、netstat で確認したところ、複数のポートを使用していました。検索してみましたが、適切な答えが見つかりませんでした

sync.mutex を試してみました:

リーリー

上記の変更により、13,000 rps が得られ、CPU 負荷は正常でしたが、単に十分ではありませんでした。

回避策

リクエストを 1 つのホストにのみ送信しているため、httpトランスポートのデフォルト値は適切ではありません。状況に応じてパラメータを手動で設定することをお勧めします:

リーリー

詳細については、こちらをご覧ください。

以上がGo でマルチスレッドリクエストが発生し、高い RPS が得られないの詳細内容です。詳細については、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)

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

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

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

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

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

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

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

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

GO言語の「VAR」と「タイプ」キーワード定義構造の違いは何ですか? GO言語の「VAR」と「タイプ」キーワード定義構造の違いは何ですか? Apr 02, 2025 pm 12:57 PM

GO言語で構造を定義する2つの方法:VARとタイプのキーワードの違い。構造を定義するとき、GO言語はしばしば2つの異なる執筆方法を見ます:最初...

Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか? Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか? Apr 02, 2025 pm 05:09 PM

Golandのカスタム構造ラベルが表示されない場合はどうすればよいですか?ゴーランドを使用するためにGolandを使用する場合、多くの開発者はカスタム構造タグに遭遇します...

GOのどのライブラリが大企業によって開発されていますか、それとも有名なオープンソースプロジェクトによって提供されていますか? GOのどのライブラリが大企業によって開発されていますか、それとも有名なオープンソースプロジェクトによって提供されていますか? Apr 02, 2025 pm 04:12 PM

大企業または有名なオープンソースプロジェクトによって開発されたGOのどのライブラリが開発されていますか? GOでプログラミングするとき、開発者はしばしばいくつかの一般的なニーズに遭遇します...

SQL.Openを使用するとき、DSNが空に渡されたときにエラーを報告しないのはなぜですか? SQL.Openを使用するとき、DSNが空に渡されたときにエラーを報告しないのはなぜですか? Apr 02, 2025 pm 12:54 PM

SQL.Openを使用する場合、DSNがエラーを報告しないのはなぜですか? GO言語では、sql.open ...

See all articles