服務器
1、介紹
讓客戶滿意是我們工作的目標,不斷超越客戶的期望值來自于我們對這個行業(yè)的熱愛。我們立志把好的技術通過有效、簡單的方式提供給客戶,將通過不懈努力成為客戶在信息化領域值得信任、有價值的長期合作伙伴,公司提供的服務項目有:國際域名空間、虛擬主機、營銷軟件、網(wǎng)站建設、單縣網(wǎng)站維護、網(wǎng)站推廣。Linux 的內核將所有外部設備都看做一個文件來操作(一切皆文件),對一個文件的讀寫操作會調用內核提供的系統(tǒng)命令,返回一個file descriptor(fd,文件描述符)。而對一個socket的讀寫也會有響應的描述符,稱為socket fd(socket文件描述符),描述符就是一個數(shù)字,指向內核中的一個結構體(文件路徑,數(shù)據(jù)區(qū)等一些屬性)。
根據(jù)UNIX網(wǎng)絡編程對I/O模型的分類,UNIX提供了5種I/O模型。
1.1、阻塞I/O模型
最常用的I/O模型,默認情況下,所有文件操作都是阻塞的。
比如I/O模型下的套接字接口:在進程空間中調用recvfrom,其系統(tǒng)調用直到數(shù)據(jù)包到達且被復制到應用進程的緩沖區(qū)中或者發(fā)生錯誤時才返回,在此期間一直等待。
進程在調用recvfrom開始到它返回的整段時間內都是被阻塞的,所以叫阻塞I/O模型。
圖示:
1.2、非阻塞I/O模型
recvfrom從應用層到內核的時候,就直接返回一個EWOULDBLOCK錯誤,一般都對非阻塞I/O模型進行輪詢檢查這個狀態(tài),看內核是不是有數(shù)據(jù)到來。
圖示:
1.3、I/O復用模型
Linux提供select/poll,進程通過將一個或多個fd傳遞給select或poll系統(tǒng)調用,阻塞在select操作上,這樣,select/poll可以幫我們偵測多個fd是否處于就緒狀態(tài)。
select/poll是順序掃描fd是否就緒,而且支持的fd數(shù)量有限,因此它的使用受到了一些制約。
Linux還提供一個epoll系統(tǒng)調用,epoll使用基于事件驅動方式代替順序掃描,因此性能更高。當有fd就緒時,立即回調函數(shù)rollback。
圖示:
1.4、信號驅動I/O模型
首先開啟套接口信號驅動I/O功能,并通過系統(tǒng)調用sigaction執(zhí)行一個信號處理函數(shù)(此系統(tǒng)調用立即返回,進程繼續(xù)工作,非阻塞)。當數(shù)據(jù)準備就緒時,就為改進程生成一個SIGIO信號,通過信號回調通知應用程序調用recvfrom來讀取數(shù)據(jù),并通知主循環(huán)函數(shù)處理樹立。
圖示:
1.5、異步I/O
告知內核啟動某個操作,并讓內核在整個操作完成后(包括數(shù)據(jù)的復制)通知進程。
信號驅動I/O模型通知的是何時可以開始一個I/O操作,異步I/O模型有內核通知I/O操作何時已經(jīng)完成。
圖示:
2、I/O多路復用技術
I/O編程中,需要處理多個客戶端接入請求時,可以利用多線程或者I/O多路復用技術進行處理。
正如前面的簡介,I/O多路復用技術通過把多個I/O的阻塞復用到同一個select的阻塞上,從而使得系統(tǒng)在單線程的情況下可以同時處理多個客戶端請求。
與傳統(tǒng)的多線程模型相比,I/O多路復用的優(yōu)勢就是系統(tǒng)開銷小,系統(tǒng)不需要創(chuàng)建新的額外線程,也不需要維護這些線程的運行,降低了系統(tǒng)的維護工作量,節(jié)省了系統(tǒng)資源。
主要的應用場景:
服務器需要同時處理多個處于監(jiān)聽狀態(tài)或多個連接狀態(tài)的套接字。 服務器需要同時處理多種網(wǎng)絡協(xié)議的套接字。支持I/O多路復用的系統(tǒng)調用主要有select、pselect、poll、epoll。
而當前推薦使用的是epoll,優(yōu)勢如下:
支持一個進程打開的socket fd不受限制。 I/O效率不會隨著fd數(shù)目的增加而線性下將。 使用mmap加速內核與用戶空間的消息傳遞。 epoll擁有更加簡單的API。3、Java中的網(wǎng)絡IO編程
如果只是做Java開發(fā),以上內容只需了解即可,不必深究(隨便說說而已)。
已專門出了文章介紹:Java 網(wǎng)絡IO編程總結(BIO、NIO、AIO均含完整實例代碼)