簡體   English   中英

JBoss + Netty +對等重置連接=線程泄漏

[英]JBoss + Netty + Connection reset by peer = Thread leak

我有一個使用netty處理與某些外部設備進行通信的應用程序。 該應用程序在JBoss EAP 6.1上運行。 看來,當設備斷開連接時,正在運行的線程數會增加,但在刪除TIME_WAIT連接后不會減少。 看起來像這樣:

  1 LISTEN
Threads:    207
  1 LISTEN
  1 TIME_WAIT
Threads:    211
  1 LISTEN
  1 TIME_WAIT
Threads:    211
  1 LISTEN
  1 TIME_WAIT
Threads:    210
  1 LISTEN
  1 TIME_WAIT
Threads:    209
  1 LISTEN
  1 TIME_WAIT
Threads:    209
  1 LISTEN
  1 TIME_WAIT
Threads:    209
  1 LISTEN
Threads:    209
  1 LISTEN
Threads:    209

如您所見,連接之前的線程數是207,當設備建立連接並斷開連接時,線程數是211-減少到209,但從不減少到207。上述情況的下一次出現都會導致線程計數增加,因此最終拋出OutOfMemory。 我在實現的每個自定義線程類的run()方法中添加了一些日志記錄,因此我可以將“線程開始”與“線程結束”進行匹配,並且似乎所有自定義線程都結束了。 這個問題可能是什么原因?

我認為您沒有在EventExecutorGroup上正常調用shutdownGracefully 那應該解決您的問題。

暫無
暫無

聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM