文件打开未关闭达到系统上限引起的错误

在使用无线网络通过mqtt
上传数据的过程中,发现无线掉线一段时间后,进程好像休眠了没有定时生成数据了,后?
赐ü魇栽诙贤那榭觯?000多次就会出现这种“休眠”,进一步跟踪日志发现,
1000多次后发现从一开始一直去打开的一个文件就会显示打开错误,
打印错误码是:24.
查看对应的错误码信息
too many open files。于是到proc/进程号文件夹/fd去查看已经打开1023个文件描述符。
查看系统文件描述限制
LEC-3070[log]# ulimit -a
-f: file size (blocks)             unlimited
-t: cpu time (seconds)             unlimited
-d: data seg size (kb)             unlimited
-s: stack size (kb)                8192
-c: core file size (blocks)        0
-m: resident set size (kb)         unlimited
-l: locked memory (kb)             64
-p: processes                      512
-n: file descriptors               1024
-v: address space (kb)             unlimited
-w: locks                          unlimited
-e: scheduling priority            0
-r: real-time priority             0
就是1024
个,所以就会报文件打开失败,然后将我原来的数据备份文件全部删掉。没有了数据文件?
没有了数据文件就导致了数据发送进程就无事可干,所以造成“休眠”的假象



查看到打开的文件描述符连接的对应文件,就知道是哪个函数打开的,
去检查确实一个地方打开就返回,却没有关闭,造成的这个问题。

有打开就有关闭,引以为戒!


文件限制修改参考此文
https://blog.youkuaiyun.com/roy_70/article/details/78423880
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值