首页 > 运维 > linux运维 > 正文

如何限制Linux用户进程数 ulimit控制用户进程技巧

P粉602998670
发布: 2025-08-22 10:12:02
原创
218人浏览过

要限制 linux 用户进程数,可通过 ulimit 命令实现。1. 查看当前限制:使用 ulimit -u 查看当前 shell 会话的进程数限制;2. 永久修改限制:编辑 /etc/security/limits.conf 添加 testuser hard/soft nproc 100,并确保 /etc/pam.d/common-session 包含 session required pam_limits.so;3. 注意事项:sudo 可能影响限制对象,cron 和 systemd 服务需额外配置;4. 监控进程数:使用 ps -u testuser -f | wc -l 统计进程数量,或使用监控工具;5. 其他资源限制:ulimit 还可限制文件大小、虚拟内存、cpu 时间和打开文件数等资源,提升系统稳定性与安全性。

如何限制Linux用户进程数 ulimit控制用户进程技巧

限制 Linux 用户进程数,主要是为了防止恶意程序或用户过度消耗系统资源,导致系统性能下降甚至崩溃。

ulimit
登录后复制
命令就是实现这个目的的强大工具。它能控制用户可以使用的各种资源,包括进程数。

如何限制Linux用户进程数 ulimit控制用户进程技巧

限制用户进程数,保障系统稳定运行,可以通过配置

ulimit
登录后复制
来实现。

如何查看当前用户的进程数限制?

想要限制,首先得知道现在的限制是多少。直接在终端输入

ulimit -u
登录后复制
就能看到当前用户的最大进程数限制。如果没有特别设置,这个值通常会比较大,甚至可能接近系统的最大进程数。

如何限制Linux用户进程数 ulimit控制用户进程技巧

但要注意,这个命令显示的是当前 shell 会话的限制。如果你修改了

ulimit
登录后复制
的值,也只会在当前会话生效。

如何永久修改用户进程数限制?

永久修改就需要编辑配置文件了。通常有两种方式:

如何限制Linux用户进程数 ulimit控制用户进程技巧
  • 修改

    /etc/security/limits.conf
    登录后复制
    : 这个文件是全局配置文件,可以针对用户或用户组设置限制。编辑这个文件需要 root 权限。

    例如,要限制用户

    testuser
    登录后复制
    的最大进程数为 100,可以在文件末尾添加:

    testuser hard nproc 100
    testuser soft nproc 100
    登录后复制

    hard
    登录后复制
    表示硬限制,用户无法超过这个值;
    soft
    登录后复制
    表示软限制,用户可以临时超过,但不能超过硬限制。通常建议 hard 和 soft 设置为相同的值。

    修改完这个文件后,需要重新登录才能生效。

  • *修改 `/etc/pam.d/common-session

    文件:**  为了让
    登录后复制
    limits.conf
    的设置生效,还需要确保 PAM 模块加载了相应的配置。编辑
    登录后复制
    /etc/pam.d/common-session
    登录后复制
    /etc/pam.d/common-session-noninteractive` 文件,确保包含以下行:

    session    required     pam_limits.so
    登录后复制

    如果没有,就添加进去。这个步骤很重要,否则

    limits.conf
    登录后复制
    的修改不会生效。

    豆包AI编程
    豆包AI编程

    豆包推出的AI编程助手

    豆包AI编程 483
    查看详情 豆包AI编程

为什么修改了 limits.conf 没生效?

这个问题很常见。除了上面提到的 PAM 模块配置问题,还有一些其他原因可能导致

limits.conf
登录后复制
不生效:

  • sudo 权限: 如果你使用

    sudo
    登录后复制
    执行命令,那么
    ulimit
    登录后复制
    限制的是 root 用户的进程数,而不是你的普通用户的进程数。要限制普通用户的进程数,应该直接以普通用户身份登录,或者使用
    su
    登录后复制
    命令切换到普通用户。

  • shell 启动方式: 有些 shell 启动时不会加载

    limits.conf
    登录后复制
    的配置。例如,cron 任务默认不会加载。如果需要在 cron 任务中应用
    ulimit
    登录后复制
    限制,需要在脚本中显式设置
    ulimit
    登录后复制

  • systemd 管理的服务: 如果你的进程是由 systemd 管理的,那么

    limits.conf
    登录后复制
    的设置可能不会生效。需要在 systemd 的 service 文件中设置
    LimitNPROC
    登录后复制
    参数。例如:

    [Service]
    LimitNPROC=100
    登录后复制

    然后重新加载 systemd 配置:

    systemctl daemon-reload
    systemctl restart your_service
    登录后复制

如何监控用户的进程数?

光限制还不够,最好能监控用户的进程数,及时发现异常情况。可以使用

ps
登录后复制
命令配合
wc
登录后复制
命令来统计用户的进程数:

ps -u testuser -f | wc -l
登录后复制

这个命令会列出用户

testuser
登录后复制
的所有进程,然后统计行数,就是进程数。可以编写一个脚本,定期执行这个命令,如果进程数超过了设定的阈值,就发送告警。

当然,更专业的监控工具,比如 Prometheus + Grafana,可以提供更强大的监控能力。

ulimit 除了限制进程数,还能限制什么?

ulimit
登录后复制
的功能远不止限制进程数。它还可以限制:

  • 文件大小 (
    -f
    登录后复制
    ):
    限制用户可以创建的最大文件大小。
  • 虚拟内存 (
    -v
    登录后复制
    ):
    限制用户可以使用的最大虚拟内存。
  • CPU 时间 (
    -t
    登录后复制
    ):
    限制用户进程可以使用的最大 CPU 时间。
  • 打开文件数 (
    -n
    登录后复制
    ):
    限制用户可以同时打开的最大文件数。这个参数对于高并发的服务器应用非常重要。

合理使用

ulimit
登录后复制
,可以有效地控制系统资源的使用,提高系统的稳定性和安全性。

以上就是如何限制Linux用户进程数 ulimit控制用户进程技巧的详细内容,更多请关注php中文网其它相关文章!

最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
热门推荐
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号