版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請(qǐng)進(jìn)行舉報(bào)或認(rèn)領(lǐng)
文檔簡(jiǎn)介
1、lighttpd1.4.18 代碼分析 代碼分析(一)--watcher,worker 模型 模型 lighttpd 是目前非常流行的 web 服務(wù)器,很多流量非常大的網(wǎng)站(如 youtube)使用的就是lighttpd,它的代碼量不多,但是設(shè)計(jì)巧妙,效率高,功能完備(這是它將來能取代 Apache 的重要因素),編碼風(fēng)格優(yōu)美, 是學(xué)習(xí)網(wǎng)絡(luò)編程,熟悉 http 服務(wù)器編寫的良好范例.在我初學(xué)網(wǎng)絡(luò)編程的時(shí)候,就是看的 lighttpd 的
2、源碼進(jìn)行學(xué)習(xí),在其中學(xué)到了不少的技巧.我打算將這些寫出來與別人分享,可能開始比較雜亂,也不會(huì)作完全的分析,因?yàn)楹芏嗖糠值拇a我也沒有看過,寫一點(diǎn)是一點(diǎn)吧.我進(jìn)行閱讀和分析的 lighttpd 版本是 1.4.18.lighttpd 采用的是多進(jìn)程+多路復(fù)用(如 select,epoll)的網(wǎng)絡(luò)模型,它對(duì)多路復(fù)用 IO 操作的封裝將作為下一個(gè)專題的內(nèi)容,本次將講解它所采用的多進(jìn)程模型.lighttpd 中的配置文件有一項(xiàng) server.m
3、ax-worker 配置的是服務(wù)器生成的工作進(jìn)城數(shù).在lighttpd 中, 服務(wù)器主進(jìn)程被稱為 watcher(監(jiān)控者),而由這個(gè)主進(jìn)程創(chuàng)建出來的子進(jìn)程被稱為 woker(工作者),而 woker 的數(shù)量正是由上面提到的配置項(xiàng)進(jìn)行配置的.watcher 創(chuàng)建并且監(jiān)控 woker 的代碼如下所示,我覺得這是一段很巧妙的代碼,在我閱讀了這段代碼之后,到目前為止,我所寫的所有服務(wù)器采用的都是類似 lighttpd 的 watcher-wok
4、er 多進(jìn)程模型,這段代碼在 src 目錄中 server.c 文件的 main 函數(shù)中:#ifdef HAVE_FORK/* start watcher and workers */num_childs = srv->srvconf.max_worker;if (num_childs > 0) {int child = 0;while (!child case 0:child = 1;break;default:num_c
5、hilds--;break;}} else {int status;/** * kill all children too */if (graceful_shutdown) {kill(0, SIGINT);} else if (srv_shutdown) {kill(0, SIGTERM);}log_error_close(srv);network_close(srv);connections_free(srv);plugins_fr
6、ee(srv);server_free(srv);return 0;}}#endif首先,woker 的數(shù)量保存在變量 num_childs 中, 同時(shí)另一個(gè)變量 child 是一個(gè)標(biāo)志位, 為 0 時(shí)是父進(jìn)程(watcher), 為 1 時(shí)則是子進(jìn)程(worker), 下面進(jìn)入一個(gè)循環(huán):while (!child 而子進(jìn)程是 worker, 是具體執(zhí)行服務(wù)器操作的工作者, 在被創(chuàng)建完畢之后退出循環(huán), 去做下面的事情.而如果父進(jìn)程退出這
溫馨提示
- 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請(qǐng)下載最新的WinRAR軟件解壓。
- 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請(qǐng)聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
- 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會(huì)有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
- 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
- 5. 眾賞文庫僅提供信息存儲(chǔ)空間,僅對(duì)用戶上傳內(nèi)容的表現(xiàn)方式做保護(hù)處理,對(duì)用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對(duì)任何下載內(nèi)容負(fù)責(zé)。
- 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請(qǐng)與我們聯(lián)系,我們立即糾正。
- 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時(shí)也不承擔(dān)用戶因使用這些下載資源對(duì)自己和他人造成任何形式的傷害或損失。
評(píng)論
0/150
提交評(píng)論