999精品在线视频,手机成人午夜在线视频,久久不卡国产精品无码,中日无码在线观看,成人av手机在线观看,日韩精品亚洲一区中文字幕,亚洲av无码人妻,四虎国产在线观看 ?

基于完成端口的網絡服務應用程序開發

2009-07-13 10:09:06王愛平
新媒體研究 2009年21期
關鍵詞:用戶

王愛平 唐 玄

[摘要]由于互聯網的普及,在線人數也越來越多,這就提高對服務器端應用程序性能的要求。因此,講述windows平臺上高性能網絡服務應用程序的開發方法。

[關鍵詞]完成端口IOCP網絡服務

中圖分類號:TP3文獻標識碼:A文章編號:1671-7597(2009)1110084-01

一、引言

隨著網絡的廣泛應用,企事業單位、公司都需要開發網絡服務應用程序,用于和客戶進行交互。網絡服務應用程序一般可采用B/S、C/S模式開發,其中,B/S模式已經廣泛地應用在WEB應用程序上。然而,要實現實時、高性能的網絡服務應用程序,仍需要采用C/S模式的開發方式。在windows操作系統環境下,使用C/S模式開發,主要考慮網絡服務程序的服務器端程序性能,能支持大量用戶并發。這就需要使用完成端口模型來開發服務器端程序。

二、使用完成端口

完成端口,又稱Input/Output Completion Port(IOCP),是windows

操作系統中非常復雜的一種I/O模型。它可以同時為大量的SOCKET提供服務,因此它是windows操作系統中開發高性能網絡應用服務器的首選。

創建完成端口時,windows操作系統會創建一個內核對象。使用完成端口時,將該內核對象與SOCKET進行關聯,則SOCKET產生的事件會通知到該完成端口,此時,就可以通過完成端口對SOCKET進行相關操作了。

使用完成端口常用3個相關函數:

1.CreateIoCompletionPort(

HANDLE FileHandle,

HANDLE ExistingCompletionPort,

ULONG_PTR CompletionKey,

DWORD NumberOfConcurrentThreads);

本函數用來創建完成端口對象、關聯完成端口對象和其他內核對象。

FileHandle是用來和完成端口對象關聯的內核對象句柄;ExistingCo

mpletionPort是已經創建好的完成端口對象句柄,FileHandle所指定的內核對象I/O事件將會通知到該完成端口對象;CompletionKey是完成鍵,可以為任何用戶指定的值,其目的是程序可以借此參數和完成端口之間傳遞值,方便與完成端口之間的通信。NumberOfConcurrentThreads用于指定同時可以并發的線程數量,取0表示并發線程數據為系統中CPU的數量。

2.GetQueuedCompletionStatus(

HANDLE CompletionPort,

LPDOWRD lpNumberOfBytesTransferred,

PULONG_PTR lpCompletionKey,

LPOVERLAPPED *lpOverlapped,

DWORD dwMilliseconds);

本函數用來獲取完成端口狀態。調用本函數后,線程掛起。當與該完成端口相關聯的內核對象I/O操作完成時,喚醒線程。

CompletionPort為完成端口對象句柄;lpNumberOfBytestTransferred

是I/O操作中傳輸的字節數;lpCompletionKey是調用CreateIoCompletionP

Ort時傳入的CompletionKey參數;lpOverlapped為LPOVERLAPPED的指針類型,是操作系統管理完成端口需要的系統類型,通常I/O傳輸緩沖區是由該結構指定的;dwMilliseconds指定超時時間。

3.PostQueruedCompletionStatus(

HANDLE CompletionPort,

DWORD dwNumberOfBytesTransferred,

ULONG_PTR lpCompletionKey,

LPOVERLAPPED *lpOverlapped);

本函數用來向完成端口發送信息以改變程序流程。

三、系統設計

服務器程序主線程程序流程:1.調用CreateIoCompletionPort函數創建完成端口;2.調用_beginthreadex函數創建一定數量工作者線程ThreadProc;3.調用socket函數創建偵聽套接字并使用listen函數在指定端口開始偵聽;4.調用WSAAccept函數等待客戶端連接(此時主線程將掛起)。當客戶端連接成功,則創建完成鍵(一般包含客戶端相關信息),關聯完成端口與WSAccept返回的新套接字句柄,并向該套接字句柄投遞一個或多個異步WSARecv或WSASend請求。循環執行本操作,直至程序結束。

服務器程序工作者線程程序流程:調用GetQueuedCompletionPort函數,線程掛起。當操作系統喚醒該線程時,GetQueuedCompletionPort返回I/O傳輸相關信息。此時,根據返回相關參數值執行相應程序。

四、改進措施

1.使用AcceptEx。由于WSAAccept調用之后,主線程將會被阻塞,直到有客戶端連接時才被喚醒;而且,當某個客戶端連接的時候,獨占主線程,其它客戶端將無法連接服務器。因此,這里可以采用異步函數AcceptEx。使用AcceptEx函數可以同時創建多個套接字,并使它們處于等待用戶連接狀態。而且,AcceptEx也采用了OVERLAPPED結構,它也可以和完成端口相關聯,可以在工作者線程中統一處理客戶端連接事件。這樣,就提高了接受客戶端連接的效率。

2.使用線程池。microsoft推薦使用的線程數為CPU數量乘以2加1,這是為了避免線程頻繁切換引起的系統開銷,這也是完成端口的優點。但實際上,服務請求所需數量不應用永遠取此值,它取決于應用程序的總體設計情況。如果系統中現有工作者線程均處于掛起或鎖定狀態,這時就需要額外創建新的工作者線程來響應I/O操作,從而提高整個系統的運行效率。

3.使用內存池。在新用戶連接服務器時,需要為每一個用戶分配一個結構體存儲OVERLAPPED結構、數據傳輸緩沖區、完成鍵等信息。如果每來一個用戶,就分配一塊內存,服務器就需要頻繁地開辟新空間;而如果每一個用戶斷開連接時,服務器就需要頻繁地釋放所占內存。這樣會導致系統性能下降。因此,服務器應用程序可以預先分配一定數量內存,當新用戶連接服務器時,從中獲取一塊標識為“未使用”的內存用于保存信息,標識為“已占用”;當該用戶斷開與服務器連接時,標識該塊內存為“未使用”。這樣,就可以有效地避免了服務器頻繁地分配與釋放內存。

五、結束語

經測試,使用完成端口設計的服務器端應用程序可以充分發揮服務器的性能,支持海量用戶連接與傳輸信息。

參考文獻:

[1]Jeffrey Richter,windows核心編程,機械工業出版社[M].北京,2005年9月.

[2]Jeffrey Richter,windows高級編程指南,清華大學出版社[M].北京,2001年12月.

猜你喜歡
用戶
雅閣國內用戶交付突破300萬輛
車主之友(2022年4期)2022-08-27 00:58:26
您撥打的用戶已戀愛,請稍后再哭
關注用戶
商用汽車(2016年11期)2016-12-19 01:20:16
關注用戶
商用汽車(2016年5期)2016-11-28 09:55:15
兩新黨建新媒體用戶與全網新媒體用戶之間有何差別
關注用戶
商用汽車(2016年6期)2016-06-29 09:18:54
關注用戶
商用汽車(2016年4期)2016-05-09 01:23:12
挖掘用戶需求尖端科技應用
Camera360:拍出5億用戶
創業家(2015年10期)2015-02-27 07:55:08
100萬用戶
創業家(2015年10期)2015-02-27 07:54:39
主站蜘蛛池模板: 91精品啪在线观看国产60岁| 伊人久久大线影院首页| 五月婷婷中文字幕| 精品欧美一区二区三区久久久| 日韩午夜伦| 天天色天天综合网| 操国产美女| 国产爽歪歪免费视频在线观看| 999精品在线视频| 毛片在线看网站| 国产人成网线在线播放va| 巨熟乳波霸若妻中文观看免费| 天堂成人av| 99视频在线免费| 91在线播放免费不卡无毒| 中文字幕啪啪| 国产中文一区二区苍井空| 亚洲中文无码h在线观看| 狠狠综合久久久久综| 亚洲91精品视频| 亚洲国产在一区二区三区| 国产精品综合色区在线观看| 国产精品久久久精品三级| 国产成人91精品免费网址在线| 久久永久精品免费视频| 夜精品a一区二区三区| 国产精品无码作爱| 久青草网站| 国产精品性| 久久夜色撩人精品国产| 欧美日韩专区| 欧美亚洲欧美| 亚洲床戏一区| 精品一区国产精品| 亚洲三级a| h视频在线播放| 91成人在线观看视频| 国产欧美视频在线| 免费无码AV片在线观看中文| 尤物亚洲最大AV无码网站| 国产视频一二三区| 亚洲精品777| 三上悠亚精品二区在线观看| 天天躁狠狠躁| 亚洲第一成网站| 综合色区亚洲熟妇在线| 波多野结衣一二三| 国产天天射| 欧美视频在线不卡| 国产91蝌蚪窝| 国产精品区网红主播在线观看| 亚洲高清在线天堂精品| 婷婷综合亚洲| 国产精品密蕾丝视频| 日韩无码黄色| 丁香婷婷激情网| 亚洲爱婷婷色69堂| 日本不卡在线播放| 强奷白丝美女在线观看| 久久永久免费人妻精品| 国产99视频在线| 91黄视频在线观看| 欧美亚洲国产日韩电影在线| 97久久免费视频| 国产精品视频导航| 四虎永久免费地址| 青青青国产视频手机| 久久成人免费| 久久五月天国产自| 蝌蚪国产精品视频第一页| 亚洲国产第一区二区香蕉| 四虎永久免费网站| 成·人免费午夜无码视频在线观看| 亚洲一区二区在线无码| 欧美在线综合视频| 国产欧美视频在线观看| 91精品视频在线播放| 乱人伦99久久| 亚洲男人的天堂久久香蕉| 香蕉久久国产超碰青草| 国产Av无码精品色午夜| 一区二区自拍|