linux网络编程之多路I/o转接服务器select
? (1)多路IO轉(zhuǎn)接服務(wù)器也叫做多任務(wù)IO服務(wù)器,其主要思想是不再由程序自己監(jiān)聽客戶端連接,取而代之的是由內(nèi)核替應(yīng)用程序監(jiān)視文件,具體實(shí)現(xiàn)模型如圖所示:
? ? ? ? ?
當(dāng)客戶端請(qǐng)求和服務(wù)器連接時(shí),內(nèi)核接收到連接指令,告訴給服務(wù)器,服務(wù)器和客戶端建立連接即可(不需要執(zhí)行accept等待阻塞的時(shí)間)。當(dāng)客戶端請(qǐng)求讀命令時(shí),內(nèi)核接收到到命令,服務(wù)器直接讀取客戶端的數(shù)據(jù)(不需要執(zhí)行read等待阻塞讀取數(shù)據(jù)的時(shí)間)。當(dāng)客戶端請(qǐng)求寫數(shù)據(jù)時(shí),內(nèi)核接收到寫命令,服務(wù)器直接把數(shù)據(jù)寫給客戶端。將等待時(shí)間縮短,內(nèi)核幫助服務(wù)器執(zhí)行等待工作,解放了服務(wù)器。
(2)select函數(shù)
? ? ? ?1)select能監(jiān)聽的文件描述符個(gè)數(shù)受限與FD_SETSIZE,一般為1024,單純改變進(jìn)程打開的文件描述符的個(gè)數(shù)并不能改變select監(jiān)聽文件個(gè)數(shù)。
? ? ? ? 2)解決1024一下的客戶端時(shí)使用select是很合適的,但如果鏈接客戶端過多,select采用的是輪詢模型,會(huì)大大降低服務(wù)器響應(yīng)效率。
? ? ? ? 3)select函數(shù)結(jié)構(gòu)
? ? ? ? ? ? ? ? ?#include<sys/select.h>
? ? ? ? ? ? ? ? #include<sys/times.h>
? ? ? ? ? ? ? ? #include<sys/types.h>
? ? ? ? ? ? ? ? #include<unistd.h>
? ? ? ? ? ? ? ? int? select(int? nfds,fd_set? *readfds,fd_set *writefds,fd_set *exceptfds,struct timeval *tineout);
? ? ? ? ? ? ? ?參數(shù)nfds:監(jiān)控的文件描述符集里最大文件描述符加1,通過這個(gè)參數(shù)會(huì)告訴內(nèi)核檢測(cè)前多少個(gè)文件描述符的狀態(tài)。
? ? ? ? ? ? ? ? ? ? ? ?readfds:監(jiān)控有讀數(shù)據(jù)到達(dá)文件描述符集合,傳入傳出參數(shù)
? ? ? ? ? ? ? ? ? ? ? ?writefds:監(jiān)控有寫數(shù)據(jù)到達(dá)文件描述符集合,傳入傳出參數(shù)
? ? ? ? ? ? ? ? ? ? ? exceptfds:監(jiān)控有異常數(shù)據(jù)到達(dá)文件描述符集合,傳入傳出參數(shù)
? ? ? ? ? ? ? ? ? ? ? timeout:定時(shí)阻塞監(jiān)控時(shí)間
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 1.NULL,永遠(yuǎn)等下去
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 2.設(shè)置timeval,等待固定時(shí)間
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? 3.設(shè)置timeval里時(shí)間均為0,檢查描述字后立即返回,輪詢
? ? ? ? ? ? ? ? ? ? ? struct? ?timeval{
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? long? ? tv_sec;
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? long? ? tv_usec;
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? };
? ? ? ? ? ? ? ? ? ? ? void? ?FD_CLR(int? fd,fd_set? *set);? ? ? //把文件描述符集合里fd清0;
? ? ? ? ? ? ? ? ? ? ? int? ? ? FD_ISSET(int? fd,fd_set? *set);? ?//測(cè)試文件描述符里fd是否置1
? ? ? ? ? ? ? ? ? ? ? void? ?FD_SET(int? fd,fd_set? *set);? ? ?//文件描述符集合里fd置1
? ? ? ? ? ? ? ? ? ? ? void? ? FD_ZERO(fd_set? *set);? ? ? ? ? //文件描述符集合里所有位清0;
? ? ? ? ? ?4)server服務(wù)器實(shí)現(xiàn)程序
? ? ? ? ? ? ? ??
? ? ? ??
??
總結(jié)
以上是生活随笔為你收集整理的linux网络编程之多路I/o转接服务器select的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 成都大熊猫繁育研究基地上午去还是下午去
- 下一篇: linux网络编程之多路I/O转接服务器