java句柄数过多解决办法

java句柄数过多解决办法

使用file-leak-detector指定为应用程序的javaagent,然后重启程序,通过file-leak-detector提供能力,可以查看句柄和线程名称的信息,可直接排查出是哪行代码问题

包下载地址:http://search.maven.org/remotecontent?filepath=org/kohsuke/file-leak-detector/1.13/file-leak-detector-1.13-jar-with-dependencies.jar

git地址:https://github.com/jenkinsci/lib-file-leak-detector

file-leak-detector启动
前置条件

两种方式,必须是在同一台机器

第一种方式(需要重启)

和项目一起启动

shell 复制代码
#查看入参解释
java -javaagent:/data/file-leak-detector.jar=http=19999,trace=/data/tracefile.log -jar project.jar
第二种方式(无需重启,但只能看到当前时间以后创建的句柄)

直接启动,并将要监控的jvm虚拟机PID指定为入参

shell 复制代码
java -jar path/to/file-leak-detector-jar-with-dependencies.jar PID  http=19999
  • PID使用需要监听的java程序进程id替换!
  • 注意这种方式,只会监控到新创建的句柄,之前的无法检测到
file-leak-detector入参解释
  1. 多个入参可以使用','隔开
shell 复制代码
http=19999,trace=/data/tracefile.log
  1. http表示启动一个mini web服务,可以通过指定端口访问
  2. trace表示开启和关闭句柄打印日志信息,打印到指定地址
file-leak-detector的使用

如果生产环境19999端口未开放,可以使用curl命令查看句柄信息

shell 复制代码
#查看全部句柄信息
curl localhost:19999
#只看每个句柄的第一行
curl localhost:19999 | grep "by thread:"
#查看每个句柄的前两行和首行
curl localhost:19999 | grep -A 2 "by thread:"
#其他命令
curl  localhost:19999 | grep "socket channel by" | wc -l
curl  localhost:19999 | grep "selector by" | wc -l
curl  localhost:19999 | grep "selector by\|socket channel by"
#样例
#4 selector by thread:Kafka-LagCheck1 on Tue Jan 09 11:24:01 CST 2024
        at java.nio.channels.spi.AbstractSelector.<init>(AbstractSelector.java:86)
        at sun.nio.ch.SelectorImpl.<init>(SelectorImpl.java:54)
        at sun.nio.ch.EPollSelectorImpl.<init>(EPollSelectorImpl.java:64)
        at sun.nio.ch.EPollSelectorProvider.openSelector(EPollSelectorProvider.java:36)
        at java.nio.channels.Selector.open(Selector.java:227)
        at org.apache.kafka.common.network.Selector.<init>(Selector.java:160)
        at org.apache.kafka.common.network.Selector.<init>(Selector.java:214)
        at org.apache.kafka.common.network.Selector.<init>(Selector.java:227)
        at org.apache.kafka.common.network.Selector.<init>(Selector.java:231)
        at org.apache.kafka.clients.consumer.KafkaConsumer.<init>(KafkaConsumer.java:749)
        at org.apache.kafka.clients.consumer.KafkaConsumer.<init>(KafkaConsumer.java:666)
        at org.apache.kafka.clients.consumer.KafkaConsumer.<init>(KafkaConsumer.java:646)
其它获得句柄数方式
shell 复制代码
#查看句柄数详情
lsof -p PID
#统计某个PID句柄数
lsof -p  PID|wc -l
更多内容请参考:https://github.com/BaoPiao/blog
相关推荐
计算机编程小咖32 分钟前
《基于大数据的农产品交易数据分析与可视化系统》选题不当,毕业答辩可能直接挂科
java·大数据·hadoop·python·数据挖掘·数据分析·spark
艾莉丝努力练剑33 分钟前
【C语言16天强化训练】从基础入门到进阶:Day 7
java·c语言·学习·算法
老华带你飞1 小时前
校园交友|基于SprinBoot+vue的校园交友网站(源码+数据库+文档)
java·数据库·vue.js·spring boot·论文·毕设·校园交友网站
自强的小白1 小时前
学习Java24天
java·学习
Ashlee_code2 小时前
香港券商櫃台系統跨境金融研究
java·python·科技·金融·架构·系统架构·区块链
还梦呦2 小时前
2025年09月计算机二级Java选择题每日一练——第五期
java·开发语言·计算机二级
2501_924890523 小时前
商超场景徘徊识别误报率↓79%!陌讯多模态时序融合算法落地优化
java·大数据·人工智能·深度学习·算法·目标检测·计算机视觉
從南走到北3 小时前
JAVA国际版东郊到家同城按摩服务美容美发私教到店服务系统源码支持Android+IOS+H5
android·java·开发语言·ios·微信·微信小程序·小程序
qianmoq4 小时前
第04章:数字流专题:IntStream让数学计算更简单
java
带只拖鞋去流浪5 小时前
Java集合(Collection、Map、转换)
java