springboot在运行过程中莫名killed问题的解决

求知探索 1年前 ⋅ 909 阅读

我们之前开发的系统是第一次基于springboot开发的,在测试阶段一直被一个问题困扰,就是程序莫名其妙就killed,没有打印什么堆栈内存不够的信息,用jamp -heap 命令也没有查找到内存有泄漏的问题。怀疑是内存不够,但是free -m看了一下,内存应该是足够的。只好在网上搜索,还真在Stack Overflow上面找到了一点提示,就是和系统的内存分配是有关系的,建一个swap空间就可以解决这个问题,尝试了一下,还真的有效。觉得应该是系统的问题,明明可以释放一些缓存空间就可以解决内存不够的问题,但是系统先觉得内存不够了,影响系统的运行了,因此先找到占内存比较多的程序,把它killed了,但是加了swap空间后,系统就不觉得内存不够了,因此java进程向其申请内存的时候,就不会导致程序killed掉,虽然加了swap空间,系统一直就没有用到。

创建swap分区方式:

1.进入root权限(如果本身是Root账户可以跳过这步)

sudo -i

2. 创建swap 分区

dd if=/dev/zero of=/swap_file bs=1M count=2048

注意:此文件的大小是count的大小乘以bs大小,上面命令的大小是2GB,这个过程可能需要等一会儿。

3 通过mkswap命令将上面新建出的文件做成swap分区

mkswap /swap_file

4 启用交换分区

swapon /swap_file

5 设置开机自动挂载

vim /etc/fstab

在文本最后中加入以下内容并保存。

/swap_file swap swap defaults 0 0

6 查看内核参数vm.swappiness中的数值是否为0,如果为0则根据实际需要调整成30或者60

cat /proc/sys/vm/swappiness

我的是0,我改成了60,通过执行

sysctl -w vm.swappiness=60 

这里需要简单说明下,在Linux系统中,可以通过查看/proc/sys/vm/swappiness内容的值来确定系统对SWAP分区的使用原则。当swappiness内容的值为0时,表示最大限度地使用物理内存,物理内存使用完毕后,才会使用SWAP分区。当swappiness内容的值为100时,表示积极地使用SWAP分区,并且把内存中的数据及时地置换到SWAP分区。注:若想永久修改,则编辑/etc/sysctl.conf文件
我们这里设置的50,就表示当物理内存少于50%时便使用交换分区。

7.关闭swap分区

swapoff /swap_file

8. 关于多个交换分区在使用上的优先级

如果你有多于一个交换文件或交换分区,你可以给它们各自分配一个优先级值(0 到 32767)。系统会在使用较低优先级的交换区域前优先使用较高优先级的交换区域。例如,如果你有一个较快的磁盘 (/dev/sda) 和一个较慢的磁盘 (/dev/sdb),给较快的设备分配一个更高的优先级。优先级可以在 fstab 中通过 pri 参数指定:

/dev/sda1 none swap defaults,pri=100 0 0    
/dev/sdb2 none swap defaults,pri=10  0 0

如果两个或更多的区域有同样的优先级,并且它们都是可用的最高优先级,页面会按照循环的方式在它们之间分配。


全部评论: 0

    我有话说: