while(true)导致的cpu过高问题
2019-06-01 本文已影响0人
雨中星辰0
作者 | 日期 |
---|---|
雨中星辰 | 20190601 |
问题背景
近日,同事告诉我他的服务部署到服务器后,cpu负载飙升,让我给看下问题。
他的服务是一个dubbo服务,放在一个java项目中的,为了保证dubbo服务不退出,在启动dubbo服务后,他添加了while(true)
让项目一直运行。
代码如下:
System.out.println("xxx服务启动成功");
while(true){
}
问题原因
问题:while(true){}
导致的。
具体原因:
一个进程如果是死循环,那么占有的CPU会很高,可以操作系统时间片运行的,到了一定时间不是会自动切换到别的进程吗?既然即便是死循环,到时间还是会切换到别的进程,为什么占用CPU会高呢?
到时候的确会切换到别的进程。
可以这样理解:当切换到别的进程时,别的进程告诉系统自己没什么事情要做,不需要那么多的时间,这个时候系统就会切换到下一个进程,直到回到这个死循环的进程上,而这个进程无论什么时候都再循环,所以一直会报告有事情要做,系统就会把尽可能多的时间分给他。
实际上是这个死循环任务用光了别的进程节省下来的时间。
解决方案:
System.out.println("xxx服务启动成功");
while(true){
Thread.sleep(1);
}
效果
添加Thread.sleep(1);
前:
image.png
添加Thread.sleep(1);
后:
image.png
通过jvisualvm的cpu曲线来看,在while(true)
中添加Thread.sleep(1);
语句后,cpu负载情况有了极大的改善。
参考资料
https://blog.csdn.net/S1amDuncan/article/details/78840031
http://blog.chinaunix.net/uid-29589379-id-5750585.html