mod_wsgi的工作模式和配置


Openstack所有提供API接口的服務都是python web server,而其本身性能很弱,目前已經將它們配置到了apache上。但對於如何設置mod_wsgi的參數,我一直沒有好好去閱讀其文檔。

參考了mod_wsgi 的兩種模式Process and Thread兩篇文章后,我來歸納一下:

目前mod_wsgi有兩種工作模式:

第一種是嵌入模式,類似於mod_python,直接在apache進程中運行,這樣的好處是不需要另外增加進程,但是壞處也很明顯,所有內存都和apache共享,如果和mod_python一樣造成內存漏洞的話,就會危害整個apache。而且如果apache是用worker mpm,mod_wsgi也就強制進入了線程模式,這樣子對於非線程安全的程序來說就沒法用了。

這種模式下需要在apache的vhost中如下設置:

WSGIScriptAlias /path /path-to-wsgi

即可生效,對於小型腳本的話,直接用這種模式即可。

 

第二種是后台模式,類似於FastCGI的后台,mod_wsgi會借apache的外殼,另外啟動一個或多個進程,然后通過socket通信和apache的進程聯系。

這種方式只要使用以下配置即可:

#啟動WSGI后台,site1是后台名字 WSGIDaemonProcess site1 processes=1 threads=15 display-name=%{GROUP} #分配當前上下文應該使用哪個WSGI后台,可以放在Location里面指定 WSGIProcessGroup site1 #根據當前上下文的ProcessGroup分配到對應的后台 WSGIScriptAlias /path /path-to-wsgi

在這種模式下,我們可以通過調節processes和threads的值來設置三種MPM的模式:prefork', 'worker', 'winnt'。

 

winnt模式
WSGIDaemonProcess example threads=25
 
        
wsgi.multithread	True
wsgi.multiprocess	False
 
        
此時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

 

后台模式由於是與apache進程分離了,內存獨立,而且可以獨立重啟,不會影響apache的進程,如果你有多個項目(django),可以選擇建立多個后台或者共同使用一個后台。

比如在同一個VirtualHost里面,不同的path對應不同的django項目,可以同時使用一個Daemon:

WSGIDaemonProcess default processes=1 threads=1 display-name=%{GROUP}

WSGIProcessGroup default

WSGIScriptAlias /project1 “/home/website/project1.wsgi”

WSGIScriptAlias /project2 “/home/website/project2.wsgi”

這樣子兩個django都使用同一個WSGI后台。

也可以把不同的項目分開,分開使用不同的后台,這樣開銷比較大,但就不會耦合在一起了。

display-name是后台進程的名字,這樣方便重啟對應的進程,而不需要全部殺掉。

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”

 

對於django 1.0以下的版本,由於官方認定不是線程安全的,所以建議使用多進程單線程模式

processes=n threads=1

對於django 1.0以后,就可以放心的使用多進程多線程模式:

processes=2 threads=64

這樣子性能會更好。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM