排查Linux下C语言句柄打开太多的问题

简介: 排查Linux下C语言句柄打开太多的问题

报错如下:

LOG save error!LogFd =NULL ,errno 24,reason = Too many open files

上面的错误,使用如下打印的:

printf("LOG save error!LogFd =NULL ,errno %d,reason = %s\n", errno, strerror(errno));

可以看到提示说,打开的太多了,没法再打开了。

排查

执行lsof命令可以查看当前的状态:

lsof

我查到如下:

30569   webs      socket:[185909]
30569   webs      socket:[182108]
30569   webs      socket:[185939]
30569   webs      socket:[185960]
30569   webs      socket:[185982]
30569   webs      socket:[186003]
30569   webs      socket:[186023]
30569   webs      socket:[186039]
30569   webs      socket:[186058]
30569   webs      socket:[186068]
30569   webs      socket:[186090]
30569   webs      socket:[186105]
30569   webs      socket:[186123]
30569   webs      socket:[186142]
30569   webs      socket:[186156]
30569   webs      socket:[186175]
30569   webs      socket:[186194]
30569   webs      socket:[186210]
30569   webs      socket:[187576]
30569   webs      socket:[186236]
30569   webs      socket:[186257]
30569   webs      socket:[187654]
30569   webs      socket:[187678]
30569   webs      socket:[186310]
30569   webs      socket:[186328]
30569   webs      socket:[186339]
30569   webs      socket:[186357]
30569   webs      socket:[189446]
30569   webs      socket:[189462]
30569   webs      socket:[189483]
30569   webs      socket:[189496]
30569   webs      socket:[189513]
30569   webs      socket:[189522]
30569   webs      socket:[189541]
30569   webs      socket:[189560]
30569   webs      socket:[189575]
30569   webs      socket:[190498]
30569   webs      socket:[189600]
30569   webs      socket:[189609]
30569   webs      socket:[189624]
30569   webs      socket:[189641]
30569   webs      socket:[189658]
30569   webs      socket:[189678]
30569   webs      socket:[188315]
30569   webs      socket:[189713]
30569   webs      socket:[190576]
30569   webs      socket:[190604]
30569   webs      socket:[189787]
30569   webs      socket:[190665]
30569   webs      socket:[189832]
30569   webs      socket:[189846]
30569   webs      socket:[189853]
30569   webs      socket:[189873]
30569   webs      socket:[189884]
30569   webs      socket:[189907]
30569   webs      socket:[189921]
30569   webs      socket:[192766]
30569   webs      socket:[189953]
30569   webs      socket:[192803]
30569   webs      socket:[189986]
30569   webs      socket:[190005]
30569   webs      socket:[190021]
30569   webs      socket:[192912]
30569   webs      socket:[190053]
30569   webs      socket:[190072]
30569   webs      socket:[190088]
30569   webs      socket:[193029]
30569   webs      socket:[190121]
30569   webs      socket:[190134]
30569   webs      socket:[193102]
30569   webs      socket:[190162]
30569   webs      socket:[190179]
30569   webs      socket:[190196]
30569   webs      socket:[190213]
30569   webs      socket:[190229]
30569   webs      socket:[190250]
30569   webs      socket:[190271]
30569   webs      socket:[190858]
30569   webs      socket:[190310]
30569   webs      socket:[190329]
30569   webs      socket:[190336]
30569   webs      socket:[190966]
30569   webs      socket:[190365]
30569   webs      socket:[190384]
30569   webs      socket:[190401]
30569   webs      socket:[190420]
30569   webs      socket:[190441]
30569   webs      socket:[190458]
30569   webs      socket:[195597]
30569   webs      socket:[195615]

一直在增加,过几秒增加一次。

经过排查,是socket的问题。

因为每隔几秒,就会使用socket函数获取一下ip造成的。

使用的是close函数关闭的。

又检查了下,是因为close函数没有彻底关闭掉socket导致的一直增加句柄的操作。

目录
相关文章
|
3月前
|
Linux C语言
百度搜索:蓝易云【Linux c语言获取本机 ip、子网掩码教程。】
需要注意的是,代码中的接口名称为"eth0",你可以根据实际情况修改为你的网络接口名称。在程序中,我们使用 `ioctl`函数进行控制操作,通过 `SIOCGIFADDR`获取IP地址,通过 `SIOCGIFNETMASK`获取子网掩码。
61 3
|
4月前
|
存储 数据挖掘 Linux
Linux C语言之时间函数精讲
Linux C语言之时间函数精讲
|
1月前
|
存储 NoSQL Unix
C语言获取Linux单网卡的多IP地址
C语言获取Linux单网卡的多IP地址
24 0
|
1月前
|
安全 Unix Linux
Linux内核中常用的C语言技巧(三)
Linux内核中常用的C语言技巧(三)
217 1
|
1月前
|
存储 算法 Linux
Linux内核中常用的C语言技巧(二)
Linux内核中常用的C语言技巧(二)
28 0
|
1月前
|
存储 安全 Linux
Linux内核中常用的C语言技巧(一)
Linux内核中常用的C语言技巧(一)
33 0
|
1月前
|
Linux 网络安全
Linux - firewall-cmd 命令添加端口规则不生效排查
Linux - firewall-cmd 命令添加端口规则不生效排查
59 0
|
2月前
|
分布式计算 安全 网络协议
Linux【问题记录 04】SSH突然无法连接排查2个小时最终解决Failed to start OpenSSH server daemon及阿里云服务器的 kdevtmpfsi 挖矿病毒处理
Linux【问题记录 04】SSH突然无法连接排查2个小时最终解决Failed to start OpenSSH server daemon及阿里云服务器的 kdevtmpfsi 挖矿病毒处理
82 0
|
3月前
|
Cloud Native Linux 测试技术
为什么使用 golang http包 会把 linux 句柄打满?
为什么使用 golang http包 会把 linux 句柄打满?
|
3天前
|
Linux
linux 常用内存检查命令
linux 常用内存检查命令
11 0

相关产品

  • 云迁移中心