socket是網(wǎng)絡(luò)編程的基礎(chǔ),本文用打電話來類比socket通信中建立TCP連接的過程。
socket函數(shù),表示你買了或者借了一部手機。
bind函數(shù),告訴別人你的手機號碼,讓他們給你打電話。
listen函數(shù),打開手機的鈴聲,而不是靜音,這樣有電話時可以立馬反應(yīng)。listen函數(shù)的第二個參數(shù),最大連接數(shù),表示最多有幾個人可以同時撥打你的號碼。不過我們的手機,最多只能有一個人打進來,要不然就提示占線。
connect函數(shù),你的朋友知道了你的號碼,通過這個號碼來聯(lián)系你。在他等待你回應(yīng)的時候,不能做其他事情,所以connect函數(shù)是阻塞的。
accept函數(shù),你聽到了電話鈴聲,接電話,accept it!然后“喂”一聲,你的朋友聽到你的回應(yīng),知道電話已經(jīng)打進去了。至此,一個TCP連接建立了。
read/write函數(shù),連接建立后,TCP的兩端可以互相收發(fā)消息,這時候的連接是全雙工的。對應(yīng)打電話中的電話煲。
close函數(shù),通話完畢,一方說“我掛了”,另一方回應(yīng)"你掛吧",然后將連接終止。實際的close(sockfd)有些不同,它不止是終止連接,還把手機也歸還,不在占有這部手機,就當是公用電話吧。
注意到,上述連接是阻塞的,你一次只能響應(yīng)一個用戶的連接請求,但在實際網(wǎng)絡(luò)編程中,一個服務(wù)器服務(wù)于多個客戶,上述方案也就行不通了,怎么辦?想一想1860,移動的聲訊服務(wù)臺,也是只有一個號碼,它怎么能同時服務(wù)那么多人呢?可以這樣理解,在你打電話到1860時,總服務(wù)臺會讓一個接線員來為你服務(wù),而它自己卻繼續(xù)監(jiān)聽有沒有新的電話接入。在網(wǎng)絡(luò)編程中,這個過程類似于fork一個子進程,建立實際的通信連接,而主進程繼續(xù)監(jiān)聽。1860的接線員是有限的,所以當連接的人數(shù)達到上線時,它會放首歌給你聽,忙等待,直到有新的空閑接線員為止。
實際網(wǎng)絡(luò)編程中,處理并發(fā)的方式還有select/poll/epoll等。
下面是一個實際的socket通信過程:
posted on 2008-10-26 17:09
ronliu 閱讀(4080)
評論(4) 編輯 收藏 引用 所屬分類:
Linux 、
Net Programming