前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >排查Linux下C语言句柄打开太多的问题

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

作者头像
手撕代码八百里
发布2023-10-19 14:13:58
1340
发布2023-10-19 14:13:58
举报
文章被收录于专栏:猿计划猿计划

报错如下:

代码语言:javascript
复制
LOG save error!LogFd =NULL ,errno 24,reason = Too many open files

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

代码语言:javascript
复制
printf("LOG save error!LogFd =NULL ,errno %d,reason = %s\n", errno, strerror(errno));

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

排查

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

代码语言:javascript
复制
lsof

我查到如下:

代码语言:javascript
复制
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导致的一直增加句柄的操作。

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-09-07,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 排查
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档