私は、ファイルの表記法で多く動作するJava Webアプリケーションを持っています。
サーブレットコンテナとしてTomcat 6を使用しています。多くのリクエストが送信されると、Tomcatは非常にメモリが不足します。私はtomcatを微調整してメモリ消費を減らす方法を知りました。 サーブレットコンテナを変更することも検討しています。
あなたは何をお勧めしますか?TomcatのメモリとCPU使用量を調整する
2
A
答えて
4
conf/server.xml
の設定では、受け入れられた/動作可能な接続番号を制限できます。
は
<Executor name="tomcatThreadPool" namePrefix="catalina-exec-"
maxThreads="16" minSpareThreads="1"/>
と
<Connector executor="tomcatThreadPool"
port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
/>
や設定ファイルの
<Connector port="8080" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443"
maxThreads='16'/>
を持って、これはあなたブレーキ必要があります。
編集:あなたのコメントに基づいてあなたのCPU数(Runtime.getRuntime().availableProcessors()
)に応じてサイズの専用スレッドプールに処理を移動することができます(ExecutorServiceとExecutorsを参照してください。)次に、保留中の数を絞る有界LinkedBlockingQueueを適用することができタスク(キューがいっぱいになると、ブロッキングの追加を行うためにRejectedExecutionHandlerを指定することを忘れないでください)。
編集2:クラスへのリンクが追加されました。そこにいくつかのサンプルがあります。
編集3:プロジェクトで使用したサンプルメソッド。
/**
* Creates a new thread pool based on some attributes
* @param poolSize the number of worker threads in the thread pool
* @param poolName the name of the thread pool (for debugging purposes)
* @param priority the base priority of the worker threads
* @param capacity the size of the task queue used
* @return the ExecutorService object
*/
private ExecutorService newPool(int poolSize,
String poolName, final int priority, int capacity) {
int cpu = Runtime.getRuntime().availableProcessors();
ExecutorService result = null;
if (poolSize != 0) {
if (poolSize == -1) {
poolSize = cpu;
}
if (capacity <= 0) {
capacity = Integer.MAX_VALUE;
}
result = new ThreadPoolExecutor(poolSize, poolSize,
120, TimeUnit.MINUTES,
new LinkedBlockingQueue<Runnable>(capacity),
new ThreadFactory() {
@Override
public Thread newThread(Runnable runnable) {
Thread t = new Thread(runnable);
t.setPriority(priority);
return t;
}
}, new RejectedExecutionHandler() {
@Override
public void rejectedExecution(Runnable r,
ThreadPoolExecutor executor) {
if (!executor.isShutdown()) {
try {
executor.getQueue().put(r);
} catch (InterruptedException ex) {
// give up
}
}
}
});
}
return result;
}
そして、あなたはそれをこのように使用することができます
ExecutorService exec = newPool(-1, "converter pool", Thread.NORM_PRIORITY, 500);
servletContext.setAttribute("converter pool", exec);
そして、あなたのサーブレットで
ExecutorService exec = (ExecutorService)servletContext
.getAttribute("converter pool");
exec.submit(new Runnable() {
public void run() {
// your code for transformation goes here
}
}
関連する問題
- 1. JavaでのスレッドのCPU /メモリ使用量を調整しますか?
- 2. プロセスごとにCPUとメモリの使用量を追跡する
- 3. ノードプロセスのCPUとメモリ使用量を制限する方法
- 4. プロセスのCPUとメモリ使用量を監視する
- 5. 私のCプログラムのCPU使用量とメモリ使用量を表示したい
- 6. WMIでプロセスのCPUとメモリ使用量を知る方法は?
- 7. メモリ使用量VS。 iPhoneのCPU使用率
- 8. CPU使用量とObject.wait
- 9. LinuxプロセスのCPU使用量とメモリ使用量を記録するためのシェルスクリプト
- 10. Javascript-動的にCPU /メモリ使用量を監視
- 11. PythonワークフローでのPostgreSQLのパフォーマンスとメモリ使用の調整
- 12. スレッドメモリとCPU使用量のトラッキング
- 13. NewockicはDockerのコンテナのCPUとメモリ使用量を表示しません
- 14. メモリ使用量
- 15. Django:select_related()とメモリ使用量
- 16. ASP.NETとメモリ使用量
- 17. メモリ使用量を調べるときにGC_FOR_ALLOCを「深刻」にしますか?
- 18. HPUXでアプリケーションのCPUおよびメモリ使用量をプログラムで取得する
- 19. Glassfish - 高いCPU使用量
- 20. レポートメモリとCPU使用量 - matlab - マルチコアLinuxサーバ
- 21. Cpuとメモリ不足例外の使用
- 22. Java APIを使用してJavaアプリケーションのCpuとメモリ使用量を取得する
- 23. Android。 CPU使用量が多すぎる
- 24. Silverlightメモリ使用量
- 25. メモリ使用量テスト
- 26. Silverlightメモリ使用量
- 27. RazorEngineメモリ使用量
- 28. CGPDFDocumentCreateWithURLメモリ使用量
- 29. Android - メモリ/ CPU使用率
- 30. TomcatのPowerShellメモリ使用
あなたは、「ファイルの規則に多くの作業」とはどういう意味ですか? –