亚洲av成人无遮挡网站在线观看,少妇性bbb搡bbb爽爽爽,亚洲av日韩精品久久久久久,兔费看少妇性l交大片免费,无码少妇一区二区三区

  免費注冊 查看新帖 |

Chinaunix

  平臺 論壇 博客 文庫
12下一頁
最近訪問板塊 發(fā)新帖
查看: 11836 | 回復: 17
打印 上一主題 下一主題

[C] 急~~~~~~~~~lsof 顯示socket資源未釋放,但是我是正常關閉了的 [復制鏈接]

論壇徽章:
0
跳轉到指定樓層
1 [收藏(0)] [報告]
發(fā)表于 2013-08-23 16:48 |只看該作者 |倒序瀏覽
20可用積分
本帖最后由 korpus 于 2013-08-27 11:08 編輯

現(xiàn)在有兩臺機器  在A機器編譯運行程序完全正常,socket關閉后,lsof -c ufs查看到沒有socket異常的情況

把程序考到B機器上去編譯,測試后,用lsof -c ufs發(fā)現(xiàn)有下面的,這太多了就會占用文件句柄資源,導致最后無法打開文件。
ufs     16617 cdadmin    8u  sock       0,6      0t0 406587399 can't identify protocol

實在不明白這是怎么回事? 有人能幫忙一下嗎?

A機器 Linux DEV1 2.6.32-131.0.15.el6.x86_64
B機器 Linux UAT1 2.6.32-131.0.15.el6.x86_64

ulimit 查看兩個機器的配置都一樣

論壇徽章:
0
2 [報告]
發(fā)表于 2013-08-23 17:09 |只看該作者
觀察到A機器上偶爾也會有 can't identify protocol  但是一會兒就消失了

論壇徽章:
17
處女座
日期:2013-08-27 09:59:352015亞冠之柏太陽神
日期:2015-07-30 10:16:402015亞冠之薩濟拖拉機
日期:2015-07-29 18:58:182015年亞洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥豬
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56雙子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
3 [報告]
發(fā)表于 2013-08-23 21:19 |只看該作者
回復 1# korpus


    通常出現(xiàn)這個錯誤都是由于程序的bug導致沒有正常關閉socket引起的。比如說mongo db就有在connect失敗時沒有正常關閉socket的總是。

論壇徽章:
0
4 [報告]
發(fā)表于 2013-08-23 21:47 |只看該作者
可能兩種情況:
1.BUG漏close()了
2.引用計數(shù)原因

有沒有父子進程?
這個問題用valgrind工具測試一下就知道了,另外如果是被動關閉一方,會有個timed_wait狀態(tài),在未消失之前,會繼續(xù)占用資源。

論壇徽章:
0
5 [報告]
發(fā)表于 2013-08-23 22:11 |只看該作者
回復 3# myworkstation


    謝謝您的關注哈。

我開始也是這么想的。同樣的代碼在兩個機器上分別編譯,運行。第一個機器上面有錯誤,第二個上面沒有。在第二個機器上面我連續(xù)跑壓力測試沒問題。但是第一個機器上面就有。太奇怪了。

在第一個機器里面,socket我都檢查了都關了。而且netstat 狀態(tài)看了也沒有異常狀態(tài),但是就是有 can't identify protocol ...

論壇徽章:
0
6 [報告]
發(fā)表于 2013-08-23 22:13 |只看該作者
回復 4# Aquester


    close都關了的,netstat -na |grep 端口號 ; lsof  -c 程序看   都沒有了異常連接。。

但是我在另一個機器上都是正常的,偶爾出現(xiàn) can't identify protocol  ,不過一會兒就沒有了

論壇徽章:
0
7 [報告]
發(fā)表于 2013-08-23 22:43 |只看該作者
korpus 發(fā)表于 2013-08-23 22:13
回復 4# Aquester


會正常消失,也說明了close()沒有漏調用,會不會是因為句柄數(shù)超過了進程允許最大的?ulimit -a看看。

論壇徽章:
0
8 [報告]
發(fā)表于 2013-08-24 00:03 |只看該作者
回復 7# Aquester


    看過 ulimit -a 都是1024,但是機器A上面的文件句柄是沒有超過1024的,超過1024會報open too many files

論壇徽章:
7
天蝎座
日期:2013-09-28 10:45:42雙子座
日期:2013-10-16 16:27:09射手座
日期:2013-10-23 10:21:32處女座
日期:2014-09-17 16:44:332015年亞洲杯之巴林
日期:2015-04-09 17:28:01冥斗士
日期:2015-11-26 16:19:0015-16賽季CBA聯(lián)賽之山東
日期:2018-03-02 23:59:31
9 [報告]
發(fā)表于 2013-08-24 02:23 |只看該作者
lsof沒用過,但是lsof是通過掃描/proc/$pid/fd/來確定打開的文件描述符的,樓主的程序打開了多少個fd全在這個文件里面得到體現(xiàn)。
具體你進去ls -lp一下就一目了然了。

另外,兩臺機器的體系結構是否一樣,干脆你就把另一臺機器的binary直接考到第二臺機器運行看看。

論壇徽章:
0
10 [報告]
發(fā)表于 2013-08-25 14:12 |只看該作者
回復 9# cxytz01


    硬件都是虛擬機安裝的,一個操作系統(tǒng)版本,但是其他設置不知道是否一樣。
您需要登錄后才可以回帖 登錄 | 注冊

本版積分規(guī)則 發(fā)表回復

  

北京盛拓優(yōu)訊信息技術有限公司. 版權所有 京ICP備16024965號-6 北京市公安局海淀分局網監(jiān)中心備案編號:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年舉報專區(qū)
中國互聯(lián)網協(xié)會會員  聯(lián)系我們:huangweiwei@itpub.net
感謝所有關心和支持過ChinaUnix的朋友們 轉載本站內容請注明原作者名及出處

清除 Cookies - ChinaUnix - Archiver - WAP - TOP