[心缘地方]同学录
首页 | 功能说明 | 站长通知 | 最近更新 | 编码查看转换 | 代码下载 | 常见问题及讨论 | 《深入解析ASP核心技术》 | 王小鸭自动发工资条VBA版
登录系统:用户名: 密码: 如果要讨论问题,请先注册。

[备忘]HashMap.get方法导致的cpu100%很高

上一篇:[备忘]慎用select into创建新表
下一篇:[备忘]tomcat8的websocket报错:未在此上下文中绑定

添加日期:2023/1/5 13:43:28 快速返回   返回列表 阅读258次
服务升级重启后,发现cpu很高,700%,
查看线程dump发现都闲着,不干活,


"bizExecutorGroup-3-24" prio=10 tid=0x00007f65dc009000 nid=0x6cef runnable [0x00007f656f19f000]
   java.lang.Thread.State: RUNNABLE
        at java.util.HashMap.get(Connection websocket closed

    

然后top -H -p 11111,找到cpu高的线程号,
在dump里查找,发现是hashMap的get方法,
搜了一下,发现一堆cpu高的文章,
果断重启后暂时OK。

这个map数据不会很多,大意了,果断换成ConcurrentHashMap。

------------------
貌似要有两个线程在同时进行put,同时触发resize,
并且之前一个桶里的两个相邻的对象在容量变了后仍然hash到了同样的数组位置中,
这样才有可能导致问题,因此这现象只偶尔出现。
------------------
 

评论 COMMENTS
没有评论 No Comments.

添加评论 Add new comment.
昵称 Name:
评论内容 Comment:
验证码(不区分大小写)
Validation Code:
(not case sensitive)
看不清?点这里换一张!(Change it here!)
 
评论由管理员查看后才能显示。the comment will be showed after it is checked by admin.
CopyRight © 心缘地方 2005-2999. All Rights Reserved