Squid中的FileDescriptor解释: 即文件描述符,是一个简单的整数,用以标明每一个被进程所打开的文件和socket。第一个打开的文件是0,第二个是1,依此类推。
遇到的现象和问题: Unix/Linux操作系统通常给每个进程能打开的文件数量强加一个限制。更甚的是,通常有一个系统级的限制。可以在命令行中用ulimit -a命令查看,多数程序运行时,报出"too many openfiles"或本例中的squid的情况都与系统中“open files”环境参数有关,也就是ulimit -n。 因为squid 的工作方式,文件描述符的限制可能会极大的影响性能。当squid 用完所有的文件描述符后,它不能接收用户新的连接。也就是说,用完文件描述符导致拒绝服务。直到一部分当前请求完成,相应的文件和socket 被关闭,squid 不能接收新请求。当squid发现文件描述符短缺时,它会发布警告。 比如我们这次遇到的“WARNING! Your cache is running out of filedescriptors” 检查当前的squid配置: 执行squidclient mgr:info命令可以查看当前squid的所有运行时参数,其中squidclient mgr:info | grep 'file desc'就可以看到关于文件描述符的配置了,例如:Maximum number of file descriptors: 16384 (这个是最大数量,当然是我们优化以后的,默认是1024,做网关代理肯定不够用了)
Largest file desc currently in use: 1640 (当前最大使用量) Number of file desc currently in use: 1301 (当前使用量) Available number of file descriptors: 15083 (剩余数量) Reserved number of file descriptors: 100 (保留数量)
通常Squid在安装过程中,执行./configure时,会根据系统中ulimit -n的输出值,来判断其最大可用的FileDescriptor。所以,在运行./configure 之前,检查你的系统的文件描述符限制是否合适,能给你避免一些麻烦。大多数情况下,1024 个文件描述符足够了。非常忙的cache可能需要4096或更多。
修改的方法:
#通常情况下,应当将FileDescriptor至少设置为ulimit -n的2倍。
第一步:将ulimit -n的数量先加大:ulimit -HSn 32768。这个通常有几种方法: 1.直接执行:ulimit -HSn 32768,但重启OS后会失效 2.编辑/etc/rc.local,加入一行:ulimit -HSn 32768,重启后生效 3.编辑/etc/security/limits.conf,重启后生效(下面2种都可以,其区别可以网上搜一下): a.* - nofile 32768 b.proxy soft nofile 32768 proxy hard nofile 32768 4.编辑/etc/init.d/squid,在该脚本执行start()动作前,加入“ulimit -HSn 32768” 第二步:将squid的filedescriptors增大,这个通常也有几种方法: 1.修改/etc/squid/squid.conf,将max_filedesc设置为32768 2.编译安装squid时,在执行configure前,先在命令行执行一次:ulimit -HSn 32768 3.编译安装squid时,在执行configure时,加上--with-maxfd=32768 参数 相比较之下,当然是第一种简单了 :)