码迷,mamicode.com
首页 > 其他好文 > 详细

ulimit 为何不生效

时间:2017-05-16 23:20:37      阅读:3240      评论:0      收藏:0      [点我收藏+]

标签:配置文件   服务器   source   java   files   

首先声明一下环境

所用用户及其操作都是通过远程登录,也就是通过 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 为何不生效

标签:配置文件   服务器   source   java   files   

原文地址:http://sharkyun.blog.51cto.com/10455795/1926316

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!