2

しばらくすると (場合によっては数分、場合によっては数日)、アプリが 100% の CPU を消費し始めます。VisualVM からわかるように、org.elasticsearch.common.netty.channel.socket.nio.NioClientSocketPipelineSink授業では常に発生しています。

また、ログからわかるように、次の例外がスローされます。

NioClientSocketPipelineSink:internalWarn:105 - Unexpected exception in the selector loop.
java.nio.channels.CancelledKeyException
    at sun.nio.ch.SelectionKeyImpl.ensureValid(SelectionKeyImpl.java:55)
    at sun.nio.ch.SelectionKeyImpl.readyOps(SelectionKeyImpl.java:69)
    at java.nio.channels.SelectionKey.isConnectable(SelectionKey.java:318)
    at org.elasticsearch.common.netty.channel.socket.nio.NioClientSocketPipelineSink$Boss.processSelectedKeys(NioClientSocketPipelineSink.java:369)
    at org.elasticsearch.common.netty.channel.socket.nio.NioClientSocketPipelineSink$Boss.run(NioClientSocketPipelineSink.java:292)
    at org.elasticsearch.common.netty.util.ThreadRenamingRunnable.run(ThreadRenamingRunnable.java:108)
    at org.elasticsearch.common.netty.util.internal.DeadLockProofWorker$1.run(DeadLockProofWorker.java:44)
    at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886)
    at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908)
    at java.lang.Thread.run(Thread.java:662)

ところで、どこに問題があるのか​​ わかりません。

ElasticSearchの問題ですか?またはNettyを組み込みましたか?または私のサーバー/アプリの構成?

Ubuntu 64 11.10、Sun Java 1.6.0_26-b03、Elastic Search 0.18.5 を使用しています。


アップデート

ElasticSearchへのリクエストごとに接続を開いたり閉じたりしようとしたためだと思われます。そして、それはある種の並行性の問題だったと思います。

起動時に Elastic Search への接続を 1 回だけ開くことで修正されました。

4

1 に答える 1

1

最新の netty バージョン (3.2.7.Final) でチェックして、修正されているかどうかを確認できますか? セレクターで無限ループを引き起こし、CPU を 100% 消費するバグを修正したと思います。

于 2011-12-22T22:06:06.720 に答える