首页 > 代码库 > ulimit 为何不生效

ulimit 为何不生效

首先声明一下环境

所用用户及其操作都是通过远程登录,也就是通过 sshd 这个程序


最近生产服务器的Java程序总是报 Too  many open files


发现启动程序的用户 weblogic  ulimit 设置并没有生效,执行 ulimit -n  看到的还是 1024.

但是系统的配置文件 设置的是 10240,自己的配置文件  .bash_profile 下设置的也是 10240


于是试着重新执行 source  ./.bash_profile

竟然报错!!

[weblogic@bogon ~]$ source ./.bash_profile 

-bash: ulimit: open files: cannot modify limit: Operation not permitted


ulimits.conf 文件是要PAM模块使用的,于是找一切关于pam模块的信息,最后找到问题的原因:

由于用户都是用 远程登录的,sshd的配置文件中有个设置下被注释了

[root@bogon ~]# grep -n UsePAM /etc/ssh/sshd_config 

108:# WARNING: ‘UsePAM no‘ is not supported in Red Hat Enterprise Linux and may cause several

111: #UsePAM yes


1. 解决办法是去掉此行注释,重启sshd服务

 

2. 重新登录 weblogic 用户,执行 ulimit  -n  验证无误,重启应用程序,使其生效。


3.最后利用下面的脚本来继续验证

for   pid   in   $(ps -aux |grep   程序名|grep -v grep |awk ‘{print $2}‘ )

do 

    cat /proc/${pid}/limits |grep ‘Max open files‘

done 



ulimit 为何不生效