Linux中的ulimit参数修改

本文详细介绍了如何在Linux系统中调整最大进程数和文件打开数限制,以提升服务器性能。通过修改limits.conf和pam.d配置,及调整ulimit参数,确保系统能处理更多并发任务。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

   当服务器在使用频繁时,经常会遇到请求不响应,导致程序运行失败,主要分两大类:

       1:系统达到最大进程数,再新创建进程时会爆出,fork进程失败

       2:当系统打开文件达到上限,再新打开文件时就会爆出 open files failed...xxxx

 

在系统中主要通过修改ulimit -n和-u参数,分别代表linux的最大进程数和最大文件打开数。

 

永久生效的方法:

修改/etc/security/limits.conf文件

在文件末尾添加

* soft nofile 204800
* hard nofile 204800
* soft nproc 204800
* hard nproc 204800
 
*             代表针对所有用户 
noproc     是代表最大进程数 
nofile     是代表最大文件打开数

2. 系统调优

        如前所述, ulimit -a 用来显示当前的各种用户进程限制。 
        Linux对于每个用户,系统限制其最大进程数。为提高性能,可以根据设备资源情况,
        设置各linux 用户的最大进程数,下面我把某linux用户的最大进程数设为10000个: 
        ulimit -u 10000 
        对于需要做许多 socket 连接并使它们处于打开状态的 Java 应用程序而言,
        最好通过使用 ulimit -n xx 修改每个进程可打开的文件数,缺省值是 1024。 
        ulimit -n 4096 将每个进程可以打开的文件数目加大到4096,缺省为1024 
         其他建议设置成无限制(unlimited)的一些重要设置是: 

        数据段长度:ulimit -d unlimited 
         最大内存大小:ulimit -m unlimited 
        堆栈大小:ulimit -s unlimited 
        CPU 时间:ulimit -t unlimited 
        虚拟内存:ulimit -v unlimited 
  
        暂时地,适用于通过 ulimit 命令登录 shell 会话期间。
        永久地,通过将一个相应的 ulimit 语句添加到由登录 shell 读取的文件中, 即特定于 shell 的用户资源文件,如: 

  1) 解除 Linux 系统的最大进程数和最大文件打开数限制:
        vi /etc/security/limits.conf
        # 添加如下的行
        * soft noproc 11000
        * hard noproc 11000
        * soft nofile 4100
        * hard nofile 4100 
       说明:* 代表针对所有用户
            noproc 是代表最大进程数
            nofile 是代表最大文件打开数 
  2) 让 SSH 接受 Login 程式的登入,方便在 ssh 客户端查看 ulimit -a 资源限制:
        a、vi /etc/ssh/sshd_config 
             把 UserLogin 的值改为 yes,并把 # 注释去掉
        b、重启 sshd 服务:
              /etc/init.d/sshd restart
  3) 修改所有 linux 用户的环境变量文件:
        vi /etc/profile 
        ulimit -u 10000
        ulimit -n 4096
        ulimit -d unlimited 
        ulimit -m unlimited 
        ulimit -s unlimited 
        ulimit -t unlimited 
        ulimit -v unlimited 

/**************************************

有时候在程序里面需要打开多个文件,进行分析,系统一般默认数量是1024,(用ulimit -a可以看到)对于正常使用是够了,但是对于程序来讲,就太少了。
修改2个文件。
  1) /etc/security/limits.conf
        vi /etc/security/limits.conf
        加上:
        * soft nofile 8192
        * hard nofile 20480
  2) /etc/pam.d/login
        session required /lib/security/pam_limits.so
        **********
        另外确保/etc/pam.d/system-auth文件有下面内容
        session required /lib/security/$ISA/pam_limits.so
        这一行确保系统会执行这个限制。
        ***********
  3) 一般用户的.bash_profile
        #ulimit -n 1024
        重新登陆ok

3. /proc目录:
  1)/proc目录里面包括很多系统当前状态的参数,例如:引用
        /proc/sys/fs/file-max
        /proc/sys/fs/inode-max


  是对整个系统的限制,并不是针对用户的;
  2)proc目录中的值可以进行动态的设置,若希望永久生效,可以修改/etc/sysctl.conf文件,并使用下面的命令确认:
        # sysctl -p

        例如增加:
        引用
        fs.file-max=xxx
        fs.inode-max=xxx

<think>嗯,用户问的是如何在Linux中使用ulimit命令修改最大锁定内存量。首先,我需要回忆一下ulimit的基本用法和相关参数ulimit是用来限制用户和进程对系统资源的使用,比如内存、文件数等。锁定内存可能涉及到mlock()这样的系统调用,用于防止内存被交换到磁盘,这对需要实时性的应用很重要。 接下来,用户需要的是具体步骤。首先得确认当前的最大锁定内存限制,可以用ulimit -l命令查看。不过可能需要root权限才能修改,或者用户需要有相应的权限。这时候可能需要提到/etc/security/limits.conf文件的配置,因为ulimit修改通常是临时的,重启后会失效,所以永久设置需要修改这个文件。 然后需要考虑用户类型,是普通用户还是某个特定用户,或者是用户组。在limits.conf里添加条目的时候,需要指定用户或组,然后设置memlock参数。比如,设置为unlimited或者具体的KB数值。修改后可能需要重新登录或者重启某些服务才能生效。 还有,可能需要提到软限制和硬限制的区别,使用-H和-S选项来设置。比如,ulimit -l 65536是设置硬限制,而ulimit -S -l 32768则是设置软限制。不过,通常锁定内存可能需要root权限,所以普通用户可能无法自行修改,这时候需要管理员介入。 另外,应用层面也需要调整,比如应用程序可能需要调用mlock(),并且需要处理可能的错误,比如ENOMEM,这时候可能需要检查限制是否足够。可能还要提到一些实际例子,比如数据库或者实时应用需要锁定内存的情况。 最后,要注意安全性和系统稳定性,锁定过多内存可能导致系统资源不足,需要合理分配。可能还要提醒用户,修改系统范围的设置需要谨慎,最好在测试环境中验证后再应用到生产环境。</think>在Linux系统中,`ulimit`命令用于设置或显示用户进程的资源限制。其中**最大锁定内存量**(`memlock`)是指允许进程通过`mlock()`或`mlockall()`系统调用将内存锁定在物理RAM中的最大值。以下是具体操作步骤: --- ### 一、查看当前限制 1. **查看当前用户的限制**: ```bash ulimit -l ``` 输出示例: ``` 64 # 默认单位为KB,即64KB ``` 2. **查看系统范围的限制**: ```bash cat /proc/sys/vm/max_locked_memory ``` --- ### 二、临时修改限制(会话内有效) 1. **修改当前会话的限制**(例如设置为1GB): ```bash ulimit -l $((1024*1024)) # 单位是KB,1GB=1048576KB ``` 2. **验证修改结果**: ```bash ulimit -l ``` --- ### 三、永久修改限制 1. **编辑系统限制配置文件**: ```bash sudo vim /etc/security/limits.conf ``` 2. **添加或修改条目**(例如为用户`your_username`设置无限制): ```ini your_username hard memlock unlimited your_username soft memlock unlimited ``` - `hard`:硬限制(不可超越) - `soft`:软限制(可临时调整) 3. **保存并重启系统**(或重新登录用户使配置生效)。 --- ### 四、应用场景与注意事项 1. **适用场景**: - 需要防止内存被交换到磁盘的实时应用(如数据库、高频交易系统)。 - 使用`mlock()`或`mlockall()`的应用程序。 2. **注意事项**: - **权限问题**:普通用户可能需要管理员授权才能修改`memlock`。 - **安全性**:过高的`memlock`可能导致系统内存不足。 - **单位换算**:`1GB = 1048576KB`,需注意换算。 --- ### 五、验证锁定内存是否生效 1. **编写测试程序**(C语言示例): ```c #include <sys/mman.h> #include <stdio.h> int main() { char *buffer = malloc(1024*1024); // 分配1MB内存 if (mlock(buffer, 1024*1024) == -1) { perror("mlock failed"); return 1; } printf("Memory locked successfully!\n"); munlock(buffer, 1024*1024); free(buffer); return 0; } ``` 2. **编译并运行**: ```bash gcc test.c -o test ./test ``` --- ### 六、常见问题 1. **错误`Cannot allocate memory`**: - 检查`ulimit -l`是否足够。 - 检查`/proc/sys/vm/max_locked_memory`的系统级限制。 2. **如何恢复默认值**: ```bash ulimit -l 64 # 临时恢复 ``` 或删除`/etc/security/limits.conf`中的相关条目并重启。 --- 通过以上步骤,您可以灵活调整Linux系统的最大锁定内存量,满足不同应用场景的需求。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值