Javaスレッドプールの使用の概要
最近のプロジェクトでは、SQL クエリを頻繁に使用したり、ファイルを書き込んだり、サブタスクを分割したりする必要がある状況に遭遇しました。プログラムのスループットを向上させるために、スレッド プールを使用します。
最初は、その数に応じてユーザーをシャーディングすることを検討してください。データベースクエリでは、Oracle では () 内の where に対するクエリの数が 1,000 を超えないという制限があるためです。したがって、900 ユーザーごとに 1 つのスライスに分割することを検討してください。各スライスは 1 つです。タスクは処理のために修正スレッド プールに渡されます。
ただし、各タスクには、クーポンのクエリと作成されるコメントの数のクエリという 2 つの大きなサブタスクがあります。これら 2 つのサブタスクは大量の SQL クエリを必要とするため、これら 2 つのサブタスクをタスクにカプセル化し、それらをスレッドに渡すことを検討しました。処理。ただし、メインタスクの実行はサブタスクの結果に依存するため、同じスレッドプールが使用されている場合、サブタスクがサブミットされた後も、ワークキューで実行されるタスクは依然としてメインタスクであり、CPU は最初に送信されたメインタスクで Future.get を待機していました () が返されると、サブタスクは実行するための CPU リソースを取得できず、タスクキューで待機しているため、プログラムは終了を待機します。したがって、送信されたタスクが CPU 時間を取得し、キュー内で常に待機しないことを期待して、スレッド プールが修正からキャッシュに変更されました。その後、これによって問題も発生しましたが、これについては次の記事で説明します。
ユーザーの請求書データが計算されるときは、テンプレート センターを呼び出して電子メールを生成する必要があり、生成された電子メールをディスクに保存する必要があります。これらは 2 つの異なる IO 集中型タスクであり、1 つはソケット上で待機しています。もう 1 つはローカル IO で待機します。キャッシュ スレッド プールにサブミットし続けると、スレッド プールがタスクごとにスレッドを生成するため、多くのリソースが消費され、CPU が頻繁にスレッドを切り替えてプログラムのスループットが低下することを考慮します。したがって、新しい修正スレッド プールを作成し、これらの後続のタスクを処理のために修正スレッド プールに送信します。スレッド プールは実行に固定数のジョブを使用します。これにより、プログラムはさまざまなブロック条件下で実行を継続でき、ブロックの作成が回避されます。大量のスレッドリソースが無駄になります。
実際、最終的なプログラムでは 5 つのスレッド プールが使用されました。グレーディングを使用する理由は次のとおりです。
プログラムの実行効率を向上させるために、最初に言語に従ってユーザーを分類し、次に次のように分けることができます。 900 人によるスライス。各スライスにはタスクがあり、各部分が処理された後、電子メールを作成するにはネットワーク IO が必要で、電子メールを保存するにはディスク IO が必要です。同じスレッド プールが使用されている場合、上位タスクによって生成されたサブタスクが修正スレッド プールに送信された後、ワーク キューは依然として上位タスクによって占有されているため、異なる種類の IO 操作がタスク キューで待機することになります。システムのスループットを向上させます。下位レベルのタスクを他のスレッド プールに送信した後、下位レベルのタスクはすぐに実行され、ネットワーク IO とディスクの読み取りと書き込みを実行できるため、操作効率が向上します。

ホット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)

ホットトピック









Java の乱数ジェネレーターのガイド。ここでは、Java の関数について例を挙げて説明し、2 つの異なるジェネレーターについて例を挙げて説明します。

Java の Weka へのガイド。ここでは、weka java の概要、使い方、プラットフォームの種類、利点について例を交えて説明します。

この記事では、Java Spring の面接で最もよく聞かれる質問とその詳細な回答をまとめました。面接を突破できるように。

Java 8は、Stream APIを導入し、データ収集を処理する強力で表現力のある方法を提供します。ただし、ストリームを使用する際の一般的な質問は次のとおりです。 従来のループにより、早期の中断やリターンが可能になりますが、StreamのForeachメソッドはこの方法を直接サポートしていません。この記事では、理由を説明し、ストリーム処理システムに早期終了を実装するための代替方法を調査します。 さらに読み取り:JavaストリームAPIの改善 ストリームを理解してください Foreachメソッドは、ストリーム内の各要素で1つの操作を実行する端末操作です。その設計意図はです

Java での日付までのタイムスタンプに関するガイド。ここでは、Java でタイムスタンプを日付に変換する方法とその概要について、例とともに説明します。

Java は、初心者と経験豊富な開発者の両方が学習できる人気のあるプログラミング言語です。このチュートリアルは基本的な概念から始まり、高度なトピックに進みます。 Java Development Kit をインストールしたら、簡単な「Hello, World!」プログラムを作成してプログラミングを練習できます。コードを理解したら、コマンド プロンプトを使用してプログラムをコンパイルして実行すると、コンソールに「Hello, World!」と出力されます。 Java の学習はプログラミングの旅の始まりであり、習熟が深まるにつれて、より複雑なアプリケーションを作成できるようになります。
