Posted on 2009-04-29 17:50
Prayer 閱讀(502)
評論(0) 編輯 收藏 引用 所屬分類:
SOCKET
收集一些網上的資料,以便參考:
http://blog.chinaunix.net/u2/69143/showart_1087349.html
當服務器close一個連接時,若client端接著發數據。根據TCP協議的規定,會收到一個RST響應,client再往這個服務器發送數據時,系統會發出一個SIGPIPE信號給進程,告訴進程這個連接已經斷開了,不要再寫了。
根據信號的默認處理規則SIGPIPE信號的默認執行動作是terminate(終止、退出),所以client會退出。若不想客戶端退出可以把SIGPIPE設為SIG_IGN
如: signal(SIGPIPE,SIG_IGN);
這時SIGPIPE交給了系統處理。
服務器采用了fork的話,要收集垃圾進程,防止僵尸進程的產生,可以這樣處理:
signal(SIGCHLD,SIG_IGN); 交給系統init去回收。
這里子進程就不會產生僵尸進程了。
在linux下寫socket的程序的時候,如果嘗試send到一個disconnected socket上,就會讓底層拋出一個SIGPIPE信號。
這個信號的缺省處理方法是退出進程,大多數時候這都不是我們期望的。因此我們需要重載這個信號的處理方法。調用以下代碼,即可安全的屏蔽SIGPIPE:
struct sigaction sa;
sa.sa_handler = SIG_IGN;
sigaction( SIGPIPE, &sa, 0 );
樓上正解.
signal設置的信號句柄只能起一次作用,信號被捕獲一次后,信號句柄就會被還原成默認值了.
sigaction設置的信號句柄,可以一直有效,值到你再次改變它的設置.