无限循环的while会导致CPU使用率飙升吗?
经常使用Young GC会导致CPU占用率飙升吗?
具有大量线程的应用程序的CPU使用率是否较高?
CPU使用率高的应用程序的线程数是多少?
处于BLOCKED状态的线程会导致CPU使用率飙升吗?
分时操作系统中的CPU是消耗us还是sy

项目上线后运行一段时间,突然发现cpu 8个逻辑核心都占用100%,心情很紧张,然后就在网上找了一些解决方法,具体如下:
1.查找哪些进程在耗cpu
进入服务器,top 命令看一下,发现进程6633占用了800%
[root@3server ~]# top
2.把进程的栈dump到文件里,以便后面的分析
[root@3server ~]# jstack 6633 > cpu1128.log
3.看看这个进程里面哪些线程在占用cpu
[root@3server ~]# top -p 6633 -H
一大片占用cpu很高的线程,选一个最高的吧,PID=5159
4.接着要看刚才dump出来的cpu日志了,里面会有6633这个进程下面每个线程的栈信息,但是是十六进制显示的,所以先把5159转换成16进制
[root@3server ~]# printf %0x 5159
[root@3server ~]# 1427
5.在cpu日志里找PID=1427的线程
[root@3server ~]# vi cpu1128.log

cpu1128.log 6.分析原因
看日志,很明显是org.hibernate.exception.ExceptionUtils.getCauseUsingWellKnowTypes(...)这里“卡住”了。这个线程是"RUNABLE"状态的,为什么会"卡住"呢?不用说了,一定是死循环。后来花了很多时间在debug状态下把这个问题重现了(Hibernate 3.3.1.GA版本,通过hessian调用远程服务器报SQLGrammarException异常,就会出现这个问题)。跟踪到hibernate源码里发现了问题:

public static int getThrowableCount(Throwable throwable) {
int count = 0;
while ( throwable != null ) {
count++;
throwable = ExceptionUtils.getCause( throwable );
}
return count;
}
这个方法里,throwable和它的cause引用的同一个SQLGrammarException对象,导致在while这里产生了死循环。这肯定是hibernate的bug了。于是把hibernate升级到3.3.2.GA(原来是3.3.1.GA,不敢升太多)问题解决。

转载于:https://blog.51cto.com/4085457/2401909

最新文章

  1. spring4 离线doc和api(自制)
  2. DevStack安装时报“download of get-pip.py failed”
  3. python操作mongodb之八地理索引空间数据
  4. 一个字 word 是16位, 一个字由两个字节组成 , 字节=byte ,一个字节8位, 位=bit 如果没有特殊说明kb 就是指 k*bit
  5. mysql下的SELECT INTO语句
  6. MySQL进程处于Waiting for table flush的分析
  7. atoi()函数(转载)
  8. github创建远程仓库
  9. mysql5.6默认情况下内存占用太大
  10. 【转载】tomcat+nginx+redis实现均衡负载、session共享(一)
  11. Promise(避免金字塔回调)
  12. Primitive Assembly
  13. day90
  14. Android 使用ColorMatrix改变图片颜色
  15. 中文目录对 sublime text 有什么影响?
  16. markdown编辑器使用指南
  17. join联表查询方法
  18. POJ 2115:C Looooops
  19. bzoj千题计划161:bzoj1589: [Usaco2008 Dec]Trick or Treat on the Farm 采集糖果
  20. 刷题向》关于一道像差分约束的数学题BZOJ1045(NORMAL)

热门文章

  1. 3-1. 基于epoll架构的视频采集端设计
  2. Java进行二元操作类型转换
  3. Go语言 可变参数
  4. 事务的传播属性及隔离级别 Spring
  5. SpringBoot事件监听机制源码分析(上) SpringBoot源码(九)
  6. Android传感器--光照传感器使用
  7. 利用opencv实现视频捕捉功能
  8. stand up meeting 12/28/2015
  9. F. 蚂蚁装修
  10. ChaosBlade--动态脚本实现 Java 实验场景