while(true)导致的cpu过高问题

作者 日期
雨中星辰 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);前:

while(true)导致的cpu过高问题_第1张图片
image.png

添加Thread.sleep(1);后:

while(true)导致的cpu过高问题_第2张图片
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

你可能感兴趣的:(while(true)导致的cpu过高问题)