Too many open files错误在Linux系统中是非常常见的。
从字面意思上看就是说程序打开的文件数过多,不过这里的files不单是文件的意思,实际上包括通讯链接、端口等。
因此称之为做句柄(handle)会更合适,因此这个错误通常叫做句柄数超出系统限制。
产生原因就是进程在某个时刻打开了超过系统限制的文件数量以及通讯链接数。
比如米虫遇到这个错误就是启动某个Web项目时,Tomcat启动报错了。
既然错误说明都很清晰了,解决问题方案自然就2个:
ulimit是Linux系统的内键功能,它具有一套参数集,用于为由它生成的shell进程及其子进程的资源使用设置限制。
Linux对于每个用户,系统限制其最大进程数。
为提高性能,可以根据设备资源情况,设置各linux 用户的最大进程数。
ulimit [-参数符] [选填:设置值]
[设置值]可以为数字和unlimited(无限制),但要注意的是并不是所有字段都可以设置为无限制
针对上面提到的Too many open files错误可以通过如下方式处理。
#同时打开的文件10240
ulimit -n 10240
#仅在本次连接生效,局部环境变量,重启会恢复默认值
vi /etc/profile
#在环境变量配置文件追加配置
ulimit -n 10240
#保存后运行source /etc/profile 或 . /etc/profile使其生效
source /etc/profile
#只对当前修改用户生效,重启不会恢复默认值
#结尾添加
#soft是警告值,hard是真正意义的阈值,超过就会报错
* soft nofile 10240
* hard nofile 10240
#可以只用一句
* - nofile 8192
#*表示所有用户,可配置用户名,如:www
www soft nofile 10240
www hard nofile 10240
#该方式可以对所有用户生效,重启不会恢复默认值
当前还没有观点发布,欢迎您留下足迹!
Linux系统一般情况下启动默认只加载系统盘,支持其他磁盘自由热插拔,如果发现自己的某些目录找不见了的时候不要慌看看是不是没有设置开机启动自动加载挂载磁盘内容,另外要特别注意首次安装系统记得磁盘挂载操作
Linux服务器测试环境或正式生产环境常常设计一些定时例行处理的操作,如日记备份转移清理等,利用Crontab+Shell脚本组合实现定期定时操作,确保不会应工作繁忙忘记任务导致环境异常
awk,一种处理文本文件的语言,强大的文本分析工具。取三位创始人Alfred Aho、Peter Weinberger和Brian Kernighan的Family Name的首字符
项目上的开发和测试环境非常多,少则数十多则上百,实际工作中实在懒得来回登录或打开各个环境,最好的方案就是给内网环境间添加一下信任关系,便于快速在环境之间切换,免去输入密码的烦恼
expect脚本由一系列expect-send对组成,等待输出中输出特定的字符,通常是一个提示符,然后发送特定的响应,特别适用于需要批量手动输入命令的自动化操作改造
Shell脚本循环读取文件常用的方案有输入重定向和管道操作,循环形式有while和for两种,具体的使用或搭配看个人习惯,个人尚未对命令进行性能验证