第一部分:(主要是命令,查看最大打开限制数量,不能解决根本问题)
MF)S8bZ1I.t0kP0 在Linux下,我们使用ulimit -n
- lsof -n |awk '{print $2}'|sort|uniq -c |sort -nr|more
在系统访问高峰时间以root用户执行上面的脚本,可能出现的结果如下:51Testing软件测试网 n*sIh2q/y#g
- # lsof -n|awk '{print $2}'|sort|uniq -c |sort -nr|more
-
131 24204 -
57 24244 -
57 24231 -
56 24264
其中第一行是打开的文件句柄数量,第二行是进程号。得到进程号后,我们可以通过ps命令得到进程的详细内容。51Testing软件测试网W@6m r/g/Y
- ps -aef|grep
24204 - mysql
24204 24162 99 16:15 ? 00:24:25 /usr/sbin/mysqld
哦,原来是mysql进程打开最多文件句柄数量。但是他目前只打开了131个文件句柄数量,远远底于系统默认值1024。
?Wb-u0X%?;e0但是如果系统并发特别大,尤其是squid服务器,很有可能会超过1024。这时候就必须要调整系统参数,以适应应用变化。Linux有硬性限制和软性限制。可以通过ulimit来设定这两个参数。方法如下,以root用户运行以下命令:51Testing软件测试网9|shmx)@r$t
- ulimit -HSn
4096
以上命令中,H指定了硬性大小,S指定了软性大小,n表示设定单个进程最大的打开文件句柄数量。个人觉得最好不要超过4096,毕竟打开的文件句柄数越多响应时间肯定会越慢。设定句柄数量后,系统重启后,又会恢复默认值。如果想永久保存下来,可以修改.bash_profile文件,可以修改 /etc/profile 把上面命令加到最后。(findsun提出的办法比较合理)
=================================================================================51Testing软件测试网K!fh9\p1f\
}xX[(i-T"a4x3Y,C0如果检查程序没有问题,那就有可能是linux默认的open files值太小,不能满足当前程序默认值的要求,比如 数据库连接池的个数,tomcat请求连接的个数等。。。
1uG Y$E8bI x N0查看当前系统open files的默认值,可执行:
- [root@pororo
script]# 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) 128161 - max locked memory
(kbytes, -l) 32 - max memory size
(kbytes, -m) unlimited - open files
(-n) 800000 - pipe size
(512 bytes, -p) 8 - POSIX message queues
(bytes, -q) 819200 - real-time priority
(-r) 0 - stack size
(kbytes, -s) 10240 - cpu time
(seconds, -t) unlimited - max user processes
(-u) 128161 - virtual memory
(kbytes, -v) unlimited - file locks
(-x) unlimited - ==========================================================================
- 第二部分:(解决的真正方法)
功能说明:控制shell程序的资源。51Testing软件测试网G(C%| B%Aza:r8K
语 法:ulimit
补充说明:ulimit为shell内建指令,可用来控制shell执行程序的资源。
8nj!C^ })` ti&b0 参 数:51Testing软件测试网w8t6bZyP I
-a
j&@4o%j eBkX4q0-c
sfw7Kv%R'l w0-d
]g-z-lku]0-f
~$k)WD%@6f'^6ffT0-H
AUc{l6q0-m
J?)lR Y0-n
-p
8p3yi] A0-s
-S
-t
N"Zf5|l)R0-u
-v
i \K*l{0
r3QR~X!T J0
}D6m:K/[s.l0
!zP#Ik)j`d#y0
5`(N"{`h,?8\[^0
*Wei&I}&f}+q?0 51Testing软件测试网kB;?+p.hG
我们公司服务器需要调整ulimit的stack size 参数调整为unlimited 无限,使用ulimit -s unlimited时只能在当时的shell见效,重开一个shell就失效了。。于是得在/etc/profile 的最后面添加ulimit -s unlimited 就可以了,source /etc/profile使修改文件生效。
|/aWo0m |c j3BB^p0
W.apn } {;h$XQ0PS:如果你碰到类似的错误提示 51Testing软件测试网|V9r)zD
ulimit: max user processes: cannot modify limit: 不允许的操作 51Testing软件测试网,Cc)v iv,k
ulimit: open files: cannot modify limit: 不允许的操作
7Ke*? r-zt URq#|0 51Testing软件测试网(U3Xo%v @W8y)Q!q
为啥root用户是可以的?普通用户又会遇到这样的问题?
?Nm8Y6\.t6n0看一下/etc/security/limits.conf大概就会明白。
y pb6An@m[0linux对用户有默认的ulimit限制,而这个文件可以配置用户的硬配置和软配置,硬配置是个上限。 51Testing软件测试网l^Jg8f)Q&J ft
超出上限的修改就会出“不允许的操作”这样的错误。
5A]:Pp4h-U-L6q,r4\0
4?kNc ?;f3I e6d0在limits.conf加上
)z ]+J |3L6\{9Ki Bx0*
*
*
*
E-HKm @0就是限制了任意用户的最大线程数和文件数为10240。