ulimit 是一个用于控制 shell 进程资源使用的命令行工具。通过设置适当的 ulimit 值,可以防止 Ubuntu 系统因为资源耗尽而崩溃。以下是一些常见的资源限制及其设置方法:
首先,你可以查看当前的资源限制:
ulimit -a
文件描述符限制(nofile)是防止系统因为打开过多文件而崩溃的重要限制。你可以通过以下命令临时设置:
ulimit -n 65535
要永久设置这个值,可以编辑 /etc/security/limits.conf 文件,添加以下内容:
* soft nofile 65535
* hard nofile 65535
进程数限制(nproc)可以防止系统因为创建过多进程而崩溃。你可以通过以下命令临时设置:
ulimit -u 4096
要永久设置这个值,可以编辑 /etc/security/limits.conf 文件,添加以下内容:
* soft nproc 4096
* hard nproc 4096
内存使用限制(memlock)可以防止进程锁定过多内存。你可以通过以下命令临时设置:
ulimit -l unlimited
要永久设置这个值,可以编辑 /etc/security/limits.conf 文件,添加以下内容:
* soft memlock unlimited
* hard memlock unlimited
堆栈大小限制(stack)可以防止进程使用过多堆栈空间。你可以通过以下命令临时设置:
ulimit -s 8192
要永久设置这个值,可以编辑 /etc/security/limits.conf 文件,添加以下内容:
* soft stack 8192
* hard stack 8192
CPU时间限制(cpu)可以防止进程占用过多CPU时间。你可以通过以下命令临时设置:
ulimit -t unlimited
要永久设置这个值,可以编辑 /etc/security/limits.conf 文件,添加以下内容:
* soft cpu unlimited
* hard cpu unlimited
数据段大小限制(data)可以防止进程使用过多数据段内存。你可以通过以下命令临时设置:
ulimit -d unlimited
要永久设置这个值,可以编辑 /etc/security/limits.conf 文件,添加以下内容:
* soft data unlimited
* hard data unlimited
核心转储文件大小限制(core)可以防止系统因为生成过大核心转储文件而崩溃。你可以通过以下命令临时设置:
ulimit -c unlimited
要永久设置这个值,可以编辑 /etc/security/limits.conf 文件,添加以下内容:
* soft core unlimited
* hard core unlimited
打开文件描述符的限制(nofile)也可以通过 sysctl 命令进行设置:
sysctl fs.file-max=100000
要永久设置这个值,可以编辑 /etc/sysctl.conf 文件,添加以下内容:
fs.file-max = 100000
修改了 /etc/security/limits.conf 或 /etc/sysctl.conf 文件后,需要重启系统或重新登录使设置生效。
通过以上步骤,你可以有效地使用 ulimit 和其他工具来防止 Ubuntu 系统因为资源耗尽而崩溃。