這是學(xué)習(xí)網(wǎng)絡(luò)編程后寫(xiě)的一個(gè)練手的小程序,可以幫助復(fù)習(xí)I/O模型,epoll使用,線程池,HTTP協(xié)議等內(nèi)容。
程序代碼是基于《Linux高性能服務(wù)器編程》一書(shū)編寫(xiě)的。
首先回顧程序中的核心內(nèi)容和主要問(wèn)題,最后給出相關(guān)代碼。
0. 功能和I/O模型
實(shí)現(xiàn)簡(jiǎn)易的HTTP服務(wù)端,現(xiàn)僅支持GET方法,通過(guò)瀏覽器訪問(wèn)可以返回相應(yīng)內(nèi)容。
I/O模型采用Reactor(I/O復(fù)用 + 非阻塞I/O) + 線程池。 使用epoll事件循環(huán)用作事件通知,如果listenfd上可讀,則調(diào)用accept,把新建的fd加入epoll中;
是已連接sockfd,將其加入到線程池中由工作線程競(jìng)爭(zhēng)執(zhí)行任務(wù)。
1. 線程池怎么實(shí)現(xiàn)?
程序采用c++編寫(xiě),要自己封裝一個(gè)簡(jiǎn)易的線程池類。大致思路是創(chuàng)建固定數(shù)目的線程(如跟核數(shù)相同),然后類內(nèi)部維護(hù)一個(gè)生產(chǎn)者—消費(fèi)者隊(duì)列。