版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡介
第14章服務(wù)器模型選擇14.1循環(huán)服務(wù)器14.2簡單并發(fā)服務(wù)器14.3TCP的高級(jí)并發(fā)服務(wù)器模型14.4IO復(fù)用循環(huán)服務(wù)器14.1循環(huán)服務(wù)器14.1.1UDP循環(huán)服務(wù)器14.1.2TCP循環(huán)服務(wù)器14.1.1UDP循環(huán)服務(wù)器1.循環(huán)服務(wù)器的服務(wù)器端2.循環(huán)服務(wù)器的客戶端1.循環(huán)服務(wù)器的服務(wù)器端19
s=socket(AF_INET,SOCK_DGRAM,0);
/*建立UDP套接字*/27
/*將套接字文件描述符綁定到本地地址和端口*/28
bind(s,(structsockaddr*)&local,sizeof(local));30
while(1)31
{32
memset(buff,0,BUFFLEN);
/*清零*/33
n=recvfrom(s,buff,BUFFLEN,0,(structsockaddr*)&to,&len);...42
}2.循環(huán)服務(wù)器的客戶端18
s=socket(AF_INET,SOCK_DGRAM,0);
/*建立UDP套接字*/28
/*發(fā)送數(shù)據(jù)*/29
sendto(s,buff,strlen(buff),0,(structsockaddr*)&server,
sizeof(server));33
n=recvfrom(s,buff,BUFFLEN,0,(structsockaddr*)&server,&len);14.1.2TCP循環(huán)服務(wù)器相比較UDP協(xié)議的循環(huán)服務(wù)器,TCP協(xié)議的循環(huán)服務(wù)器的主處理過程中多了一個(gè)accept的過程,服務(wù)器在此處等待客戶端的連接,由于accept()函數(shù)為阻塞函數(shù),所以通常情況下,服務(wù)器會(huì)在此處進(jìn)行等待。對accept()函數(shù)的不同處理是區(qū)別各種服務(wù)器類型的一個(gè)重要依據(jù)。1.TCP循環(huán)服務(wù)器介紹2.服務(wù)器端代碼1.TCP循環(huán)服務(wù)器介紹TCP服務(wù)器使用socket()函數(shù)建立套接字文件描述符后,對地址和套接字文件描述符使用bind()函數(shù)進(jìn)行綁定,使用listen()函數(shù)設(shè)定偵聽的隊(duì)列長度,然后進(jìn)入循環(huán)服務(wù)器的主處理過程。2.服務(wù)器端代碼服務(wù)器端的代碼如下:20
/*建立TCP套接字*/21
s_s=socket(AF_INET,SOCK_STREAM,0);29
/*將套接字文件描述符綁定到本地地址和端口*/30
bind(s_s,(structsockaddr*)&local,sizeof(local));31
listen(s_s,BACKLOG);
/*偵聽*/34
while(1)35
{36
/*接收客戶端連接*/37
s_c=
accept(s_s,(structsockaddr*)&from,&len);38
memset(buff,0,BUFFLEN);
/*清零*/39
n=recv(s_c,buff,BUFFLEN,0);
/*接收發(fā)送方數(shù)據(jù)*/...48
}3.客戶端客戶端的程序先建立一個(gè)TCP類型的套接字,然后設(shè)置請求服務(wù)器的地址和端口網(wǎng)絡(luò)地址結(jié)構(gòu)。16
/*建立TCP套接字*/17
s=socket(AF_INET,SOCK_STREAM,0);...25
/*連接服務(wù)器*/26
connect(s,(struct
sockaddr*)&server,sizeof(server));27
memset(buff,0,BUFFLEN);
/*清零*/28
strcpy(buff,"TIME");
/*復(fù)制發(fā)送字符串*/29
/*發(fā)送數(shù)據(jù)*/30
send(s,buff,strlen(buff),0);31
memset(buff,0,BUFFLEN);
/*清零*/32
/*接收數(shù)據(jù)*/
33
n=recv(s,buff,BUFFLEN,0);14.2簡單并發(fā)服務(wù)器14.2.1并發(fā)服務(wù)器的模型14.2.2UDP并發(fā)服務(wù)器14.2.3TCP并發(fā)服務(wù)器14.2.1并發(fā)服務(wù)器的模型在服務(wù)器端,主程序提前構(gòu)建多個(gè)子進(jìn)程,當(dāng)客戶端的請求到來的時(shí)候,系統(tǒng)從進(jìn)程池中選取一個(gè)子進(jìn)程處理客戶端的連接,每個(gè)子進(jìn)程處理一個(gè)客戶端的請求,在全部子進(jìn)程的處理能力得到滿足之前,服務(wù)器的網(wǎng)絡(luò)負(fù)載是基本不變的。14.2.2UDP并發(fā)服務(wù)器上述并發(fā)服務(wù)器模型在UDP協(xié)議的實(shí)現(xiàn)模式如圖所示。1.UDP并發(fā)服務(wù)器介紹2.UDP并發(fā)服務(wù)器的例子1.UDP并發(fā)服務(wù)器介紹在建立套接字文件描述符后,對描述符和本地的地址端口進(jìn)行綁定。然后fork()多個(gè)子進(jìn)程,客戶端請求的處理在子進(jìn)程中進(jìn)行。2.UDP并發(fā)服務(wù)器的例子對于客戶端的請求,有多個(gè)子進(jìn)程進(jìn)行處理。與循環(huán)服務(wù)器相比較,并發(fā)的UDP程序,在處理客戶端請求的時(shí)候,不再簡單地使用一個(gè)while進(jìn)行客戶端請求的串行處理,而是fork一個(gè)進(jìn)程,將客戶端的請求放到一個(gè)進(jìn)程中進(jìn)行處理。63
for(i=0;i<PIDNUMB;i++)64
{65
pid[i]=fork();66
if(pid[i]==0)
/*子進(jìn)程*/67
{68
handle_connect(s_s);69
}70
}14.2.3TCP并發(fā)服務(wù)器簡單并發(fā)服務(wù)器的TCP模型相比較UDP協(xié)議的并發(fā)服務(wù)器,TCP協(xié)議的并發(fā)服務(wù)器的主處理過程中多了一個(gè)accept的過程,服務(wù)器在此處等待客戶端的連接,由于accept()函數(shù)為阻塞函數(shù),所以通常情況下,服務(wù)器會(huì)在此處等待。對accept()函數(shù)的不同處理是區(qū)別各種服務(wù)器類型的一個(gè)重要依據(jù)。1.TCP并發(fā)服務(wù)器介紹2.TCP并發(fā)服務(wù)器的例子1.TCP并發(fā)服務(wù)器介紹TCP服務(wù)器使用socket()函數(shù)建立套接字文件描述符后,對地址和套接字文件描述符使用bind()函數(shù)進(jìn)行綁定,使用listen()函數(shù)設(shè)定偵聽的隊(duì)列長度,然后進(jìn)入并發(fā)服務(wù)器的主處理過程。2.TCP并發(fā)服務(wù)器的例子在處理客戶端請求之前,程序先分叉了3個(gè)子進(jìn)程,對應(yīng)多個(gè)客戶端的請求,由多個(gè)子進(jìn)程進(jìn)行處理。52
/*建立TCP套接字*/53
s_s=socket(AF_INET,SOCK_STREAM,0);...61
/*將套接字文件描述符綁定到本地地址和端口*/62
bind(s_s,(structsockaddr*)&local,sizeof(local));63
listen(s_s,BACKLOG);
/*偵聽*/64
65
/*處理客戶端連接*/66
pid_tpid[PIDNUMB];67
inti=0;68
for(i=0;i<PIDNUMB;i++)69
{70
pid[i]=fork();71
if(pid[i]==0)
/*子進(jìn)程*/72
{73
handle_connect(s_s);74
}75
}14.3TCP的高級(jí)并發(fā)服務(wù)器模型14.3.1單客戶端單進(jìn)程,統(tǒng)一accept()14.3.2單客戶端單線程,統(tǒng)一accept()14.3.3單客戶端單線程,各線程獨(dú)自accept(),使用互斥鎖14.3.1單客戶端單進(jìn)程,統(tǒng)一accept()在14.2節(jié)中介紹了簡單的并發(fā)服務(wù)器模型,模型中服務(wù)器在客戶端到來之前就預(yù)分叉了多個(gè)子進(jìn)程用于處理客戶端的連接請求。1.原型介紹2.例子代碼1.原型介紹本節(jié)中介紹的并發(fā)服務(wù)器模型并不預(yù)先分叉進(jìn)程,而是由主進(jìn)程統(tǒng)一處理客戶端的連接,當(dāng)客戶端的連接請求到來時(shí),才臨時(shí)fork()進(jìn)程,由子進(jìn)程處理客戶端的請求。這種模型將客戶端的連接請求和業(yè)務(wù)處理進(jìn)行了分離,相比較來說條理更清晰。2.例子代碼TCP并發(fā)服務(wù)器,在處理客戶端請求之前,程序先分叉了3個(gè)子進(jìn)程,對于多個(gè)客戶端的請求,由多個(gè)子進(jìn)程進(jìn)行處理。與循環(huán)服務(wù)器相比較,并發(fā)的TCP程序,在處理客戶端請求時(shí),不再簡單地使用一個(gè)while進(jìn)行客戶端請求的串行處理。14.3.2單客戶端單線程,統(tǒng)一accept()與進(jìn)程相比較,線程有很多優(yōu)點(diǎn),例如速度快、占用資源少、數(shù)據(jù)可以共享等。14.3.3單客戶端單線程,各線程獨(dú)自accept(),使用互斥鎖本節(jié)介紹的模型為預(yù)先分配線程,而不是進(jìn)程的模型。在線程的accept()函數(shù)中,多個(gè)線程都可以使用此函數(shù)處理客戶端的連接。為了防止沖突,使用了線程互斥鎖。在調(diào)用函數(shù)之前鎖定,調(diào)用函數(shù)accept()之后,釋放鎖。14.4IO復(fù)用循環(huán)服務(wù)器14.4.1IO復(fù)用循環(huán)服務(wù)器模型介紹14.4.2IO復(fù)用循環(huán)服務(wù)器模型的例子14.4.1IO復(fù)用循環(huán)服務(wù)器模型介紹與通常的TCP服務(wù)器相同,這種服務(wù)器首先要調(diào)用soc
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 人人文庫網(wǎng)僅提供信息存儲(chǔ)空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。
最新文檔
- 對企業(yè)有利的加班合同(2篇)
- 二零二五年智能家電技術(shù)服務(wù)合同范本3篇
- 宜賓酒王二零二五年度800億控量保價(jià)市場占有率提升合同2篇
- 二零二五年度酒店會(huì)議住宿套餐定制合同2篇
- 2025年度電子信息產(chǎn)業(yè)設(shè)備采購與技術(shù)服務(wù)合同3篇
- 二零二五版工程款分期支付還款協(xié)議合同范本3篇
- 二零二五版碧桂園集團(tuán)施工合同示范文本6篇
- 二零二五版豆腐出口貿(mào)易代理合同3篇
- 二零二五年度韻達(dá)快遞業(yè)務(wù)承包合同及綜合運(yùn)營支持協(xié)議3篇
- 2024年物流運(yùn)輸承包合同3篇
- 《文化苦旅》讀書分享 PPT
- 氧化鋁生產(chǎn)工藝教學(xué)拜耳法
- 2023年十八項(xiàng)醫(yī)療核心制度考試題與答案
- 氣管切開患者氣道濕化的護(hù)理進(jìn)展資料 氣管切開患者氣道濕化
- 管理模板:某跨境電商企業(yè)組織結(jié)構(gòu)及部門職責(zé)
- 底架總組裝工藝指導(dǎo)書
- 簡單臨時(shí)工勞動(dòng)合同模板(3篇)
- 聚酯合成反應(yīng)動(dòng)力學(xué)
- 自動(dòng)控制原理全套課件
- 上??萍即髮W(xué),面試
- 《五年級(jí)奧數(shù)總復(fù)習(xí)》精編課件
評論
0/150
提交評論