mod_wsgi的工作模式和配置
Openstack所有提供API接口的服務(wù)都是python web server,而其本身性能很弱,目前已經(jīng)將它們配置到了apache上。但對(duì)于如何設(shè)置mod_wsgi的參數(shù),我一直沒有好好去閱讀其文檔。
參考了mod_wsgi 的兩種模式和Process and Thread兩篇文章后,我來歸納一下:
目前mod_wsgi有兩種工作模式:
第一種是嵌入模式,類似于mod_python,直接在apache進(jìn)程中運(yùn)行,這樣的好處是不需要另外增加進(jìn)程,但是壞處也很明顯,所有內(nèi)存都和apache共享,如果和mod_python一樣造成內(nèi)存漏洞的話,就會(huì)危害整個(gè)apache。而且如果apache是用worker mpm,mod_wsgi也就強(qiáng)制進(jìn)入了線程模式,這樣子對(duì)于非線程安全的程序來說就沒法用了。
這種模式下需要在apache的vhost中如下設(shè)置:
WSGIScriptAlias /path /path-to-wsgi即可生效,對(duì)于小型腳本的話,直接用這種模式即可。
?
第二種是后臺(tái)模式,類似于FastCGI的后臺(tái),mod_wsgi會(huì)借apache的外殼,另外啟動(dòng)一個(gè)或多個(gè)進(jìn)程,然后通過socket通信和apache的進(jìn)程聯(lián)系。
這種方式只要使用以下配置即可:
#啟動(dòng)WSGI后臺(tái),site1是后臺(tái)名字 WSGIDaemonProcess site1 processes=1 threads=15 display-name=%{GROUP}#分配當(dāng)前上下文應(yīng)該使用哪個(gè)WSGI后臺(tái),可以放在Location里面指定 WSGIProcessGroup site1#根據(jù)當(dāng)前上下文的ProcessGroup分配到對(duì)應(yīng)的后臺(tái) WSGIScriptAlias /path /path-to-wsgi在這種模式下,我們可以通過調(diào)節(jié)processes和threads的值來設(shè)置三種MPM的模式:prefork', 'worker', 'winnt'。
?
winnt模式 WSGIDaemonProcess example threads=25 wsgi.multithread True wsgi.multiprocess False 此時(shí)processes=1,但是multiprocess為false如果顯式地指出processes為1那么: WSGIDaemonProcess example processes=1 threads=25 wsgi.multithread True wsgi.multiprocess True worker模式 WSGIDaemonProcess example processes=2 threads=25 wsgi.multithread True wsgi.multiprocess True
preforker模式 WSGIDaemonProcess example processes=5 threads=1 wsgi.multithread False wsgi.multiprocess True
?
后臺(tái)模式由于是與apache進(jìn)程分離了,內(nèi)存獨(dú)立,而且可以獨(dú)立重啟,不會(huì)影響apache的進(jìn)程,如果你有多個(gè)項(xiàng)目(django),可以選擇建立多個(gè)后臺(tái)或者共同使用一個(gè)后臺(tái)。
比如在同一個(gè)VirtualHost里面,不同的path對(duì)應(yīng)不同的django項(xiàng)目,可以同時(shí)使用一個(gè)Daemon:
WSGIDaemonProcess default processes=1 threads=1 display-name=%{GROUP}WSGIProcessGroup defaultWSGIScriptAlias /project1 “/home/website/project1.wsgi”WSGIScriptAlias /project2 “/home/website/project2.wsgi”這樣子兩個(gè)django都使用同一個(gè)WSGI后臺(tái)。
也可以把不同的項(xiàng)目分開,分開使用不同的后臺(tái),這樣開銷比較大,但就不會(huì)耦合在一起了。
display-name是后臺(tái)進(jìn)程的名字,這樣方便重啟對(duì)應(yīng)的進(jìn)程,而不需要全部殺掉。
WSGIDaemonProcess site1 processes=1 threads=1 display-name=%{GROUP}WSGIDaemonProcess site2 processes=1 threads=1 display-name=%{GROUP}<Location “/project1″> WSGIProcessGroup site1 </Location> WSGIScriptAlias /project1 “/home/website/project1.wsgi”<Location “/project1″> WSGIProcessGroup site2 </Location> WSGIScriptAlias /project2 “/home/website/project2.wsgi”?
對(duì)于django 1.0以下的版本,由于官方認(rèn)定不是線程安全的,所以建議使用多進(jìn)程單線程模式
processes=n threads=1
對(duì)于django 1.0以后,就可以放心的使用多進(jìn)程多線程模式:
processes=2 threads=64
這樣子性能會(huì)更好。
?
總結(jié)
以上是生活随笔為你收集整理的mod_wsgi的工作模式和配置的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 放学默示录Ⅰ:来!抠奖 移动游戏策划案
- 下一篇: 怎样判断网页是静态还是伪静态呢