控制启动进程占用的资源——ulimit命令

本文介绍了ulimit命令的作用及参数配置,包括如何查看和设置进程资源限制,并提供了具体的使用示例。此外,还详细说明了如何通过修改limits.conf和profile文件使ulimit设置永久生效。

1、作用
ulimit为shell内建指令,用于shell启动进程所占用的资源。

2、参数

-a  显示目前资源限制的设定。
-c <core文件上限>  设定core文件的最大值,单位为区块。
-d <数据节区大小>  程序数据节区的最大值,单位为KB-f <文件大小>  shell所能建立的最大文件,单位为区块。
-H  设定资源的硬性限制,也就是管理员所设下的限制。
-m <内存大小>  指定可使用内存的上限,单位为KB-n <文件数目>  指定同一时间最多可开启的文件数。
-p <缓冲区大小>  指定管道缓冲区的大小,单位512字节。
-s <堆叠大小>  指定堆叠的上限,单位为KB-S  设定资源的弹性限制。
-t <CPU时间>  指定CPU使用时间的上限,单位为秒。
-u <程序数目>  用户最多可开启的程序数目。
-v <虚拟内存大小>  指定可使用的虚拟内存上限,单位为KB

3、用法举例
ulimit -a:用来显示当前的各种用户进程限制。
ulimit -u 10000:设置linux用户的最大进程数设为10000个。
ulimit -n 4096:将每个进程可以打开的文件数目加大到4096,默认为1024

相应的用法可选相应的参数即可。但是此种用法只对向前shell界面有效,如果关闭当前shell,就会恢复之前设置,要想将我们的更改永久生效,请看下面。

4、永久生效

//1、修改limits.conf文件
//进入limits.conf文件
vim /etc/security/limits.conf
//在其文件末加(自己可适当修改)
* hard nofile 1000000
* soft nofile 1000000
* soft core unlimited
* soft stack 10240
* soft    nproc   131072
* hard    nproc   131072
* soft    core    unlimited
* hard    core    unlimited
* soft    memlock 50000000
* hard    memlock 50000000
elastic soft memlock unlimited
elastic hard memlock unlimited
elastic soft nofile 300000
elastic hard nofile 300000

//2、修改profile文件
//进入profile文件
vim /etc/profile
//在其文件末加
ulimit -s unlimited

//3、重启profile文件使其生效
source /etc/profile
### ulimit 命令概述 `ulimit` 是 Linux 中的一个内置 Shell 命令,主要用于查看或设置用户进程资源限制。通过该命令,管理员可以有效地管理单个用户或用户组所能使用的系统资源最大量,例如文件大小、内存使用、CPU 时间等[^2]。 此命令对于多用户环境下的系统性能管理和稳定性保障尤为重要。它可以防止某些恶意或失控的进程过度占用系统资源,从而导致其他正常运行的任务受到影响[^1]。 --- ### 查看当前资源限制 要查看当前所有的资源限制配置,可执行以下命令: ```bash ulimit -a ``` 这会显示一系列默认的资源限制项及其对应的值。例如: - `core file size (blocks)` 表示核心转储文件的最大尺寸。 - `data seg size (kbytes)` 表示数据段的最大大小。 - `file size (blocks)` 表示创建文件的最大尺寸。 - `open files (-n)` 表示每个进程中打开文件描述符的数量限制。 - `max user processes (-u)` 表示单个用户可启动的最大进程数。 以上信息可以通过具体参数单独查询或调整[^5]。 --- ### 设置资源限制 #### 临时更改(仅限当前 Shell) 如果只需要在当前 Shell 会话中应用新的资源限制,则可以直接输入相应的 `ulimit` 参数。例如: - **限制文件大小**: 将新创建文件的最大尺寸设为 1GB: ```bash ulimit -f 1048576 ``` - **限制打开文件数量**: 将每进程允许打开的文件描述符数量限制为 2048: ```bash ulimit -n 2048 ``` - **限制 CPU 时间**: 设定某进程最多只能运行 30 秒钟: ```bash ulimit -t 30 ``` 注意,这种类型的修改只会在当前终端会话期间生效,在关闭终端后恢复原状[^2]。 #### 永久更改(写入配置文件) 为了实现永久性的资源限制设定,通常需要编辑特定用户的配置文件或者全局配置文件。常见的做法如下: - 编辑 `/etc/security/limits.conf` 文件来定义硬限制和软限制。例如: ``` username soft nofile 1024 username hard nofile 2048 ``` 上述例子表示将用户名为 `username` 的用户开放文件描述符的软限制设为 1024,硬限制设为 2048。 - 对于更复杂的场景,还可以利用 PAM 配置模块或其他初始化脚本完成进一步定制化需求[^3]。 --- ### 硬限制与软限制的区别 `ulimit` 支持两种不同级别的限制——硬限制 (`hard limit`) 和软限制 (`soft limit`)。两者的区别在于权限范围以及灵活性方面: - **硬限制**:由超级用户(root)设定,普通用户无法提升其数值; - **软限制**:可以在不超过硬限制的前提下动态增加至接近硬限制的程度;超出软限时可能会触发警告提示。 当操作涉及这两种模式切换时,需分别指定 `-H` 或者 `-S` 参数[^3]。 --- ### 解决常见问题 假如遇到因资源不足引发的应用崩溃等问题,可能是因为现有配额过低所致。此时可通过适当放宽相关约束予以缓解。比如针对频繁报错 “Too many open files”,则应考虑增大对应字段限额: ```bash ulimit -Sn 4096 # 提高软限制到 4096 ulimit -Hn 8192 # 同步更新硬限制至更高水平 ``` 另外值得注意的是,部分发行版可能存在额外的安全策略机制干扰实际效果评估过程,因此建议结合实际情况综合分析处理方案[^4]。 --- ### 总结 综上所述,掌握好如何运用 `ulimit` 这一强大工具可以帮助我们更好地掌控服务器上的各项资源配置情况,并及时预防潜在风险隐患的发生。无论是日常运维还是紧急故障排查阶段都能发挥重要作用。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值