Linux中的ulimit参数修改

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

       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

  • 1
    点赞
  • 20
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
`ulimit`是Linux/Unix系统下一个用于控制进程资源限制的命令。使用`ulimit`命令可以查看或设置进程在运行时可以使用的各种资源限制,包括CPU时间,内存大小,文件打开数等等。 `ulimit -a`命令会列出当前进程所能使用的所有资源限制,如下所示: ``` core file size (blocks, -c) 0 data seg size (kbytes, -d) unlimited scheduling priority (-e) 0 file size (blocks, -f) unlimited pending signals (-i) 63522 max locked memory (kbytes, -l) 64 max memory size (kbytes, -m) unlimited open files (-n) 1024 pipe size (512 bytes, -p) 8 POSIX message queues (bytes, -q) 819200 real-time priority (-r) 0 stack size (kbytes, -s) 8192 cpu time (seconds, -t) unlimited max user processes (-u) 63522 virtual memory (kbytes, -v) unlimited file locks (-x) unlimited ``` 上述输出显示了当前进程可以使用的所有资源限制,以及各个限制的具体值。 常用的`ulimit`命令参数包括: - `-c`:core文件的最大值(单位为blocks)。 - `-d`:进程数据段的最大值(单位为KB)。 - `-f`:文件大小的最大值(单位为blocks)。 - `-n`:打开文件的最大数量。 - `-t`:进程CPU时间的最大值(单位为秒)。 - `-v`:进程虚拟内存的最大值(单位为KB)。 - `-m`:进程物理内存的最大值(单位为KB)。 例如,要将当前进程可以打开的最大文件数设置为2048,可以使用如下命令: ``` ulimit -n 2048 ``` 需要注意的是,`ulimit`命令所做的设置只对当前进程及其子进程有效,而对其他进程没有影响。如果需要全局修改系统的资源限制,需要修改系统配置文件。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值