基于python的web項目,常見的部署方法有:
- fcgi:用spawn-fcgi或者框架自帶的工具對各個project分別生成監(jiān)聽進程,然后和http服務(wù)互動。
- wsgi:利用http服務(wù)的mod_wsgi模塊來跑各個project。
不過還有個uwsgi,它既不用wsgi協(xié)議也不用fcgi協(xié)議,而是自創(chuàng)了一個uwsgi的協(xié)議,據(jù)作者說該協(xié)議大約是fcgi協(xié)議的10倍那么快。uWSGI的主要特點如下:
- 超快的性能。
- 低內(nèi)存占用(實測為apache2的mod_wsgi的一半左右)。
- 多app管理。
- 詳盡的日志功能(可以用來分析app性能和瓶頸)。
- 高度可定制(內(nèi)存大小限制,服務(wù)一定次數(shù)后重啟等)。
環(huán)境ubuntu 12.04 IP:10.1.6.79
安裝nginx
1
|
apt-get install nginx-full nginx-common |
nginx配置/etc/nginx/sites-enabled/example
1
2
3
4
5
6
7
8
9
10
11
12
13
|
server { listen 80; server_name 10.1.6.79; access_log /var/log/nginx/example_access.log; error_log /var/log/nginx/example_error.log; root /var/www/example; location / { uwsgi_pass 127.0.0.1:9001; include uwsgi_params; uwsgi_param UWSGI_SCHEME $scheme; uwsgi_param SERVER_SOFTWARE nginx/$nginx_version; } } |
安裝uwsgi
1
|
apt-get install uwsgi uwsgi-plugin-python |
如果你想安裝所有的uwsgi插件,則可以安裝uwsgi-plugin-all軟件包
uwsgi配置/etc/uwsgi/apps-enabled/default.xml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
< uwsgi > < plugin >python</ plugin > < socket >127.0.0.1:9001</ socket > < pythonpath >/var/www/example/app/</ pythonpath > < app mountpoint = "/" > < script >wsgi_configuration_module</ script > </ app > < master /> < processes >4</ processes > < reload-mercy >8</ reload-mercy > < cpu-affinity >1</ cpu-affinity > < max-requests >2000</ max-requests > < limit-as >512</ limit-as > < reload-on-as >256</ reload-on-as > < reload-on-rss >192</ reload-on-rss > < no-orphans /> < vacuum /> </ uwsgi > |
uwsgi配置文件中的參數(shù)也可以在命令行通過uwsgi指定,配置文件除了xml格式外,還可以寫成ini格式的,軟件包安裝完畢后在/usr/share/doc/uwsgi/examples/conffile目錄下會有一些xml和ini格式配置文件的例子。
wsgi_configuration_module.py腳本內(nèi)容
1
2
3
4
5
6
7
8
9
10
11
12
|
#!/usr/bin/python import os import sys sys.path.append( '/var/www/example/app' ) os.environ[ 'PYTHON_EGG_CACHE' ] = '/var/www/example/.python-egg' def application(environ, start_response): status = '200 OK' output = 'Hello World!' response_headers = [( 'Content-type' , 'text/plain' ), ( 'Content-Length' , str ( len (output)))] start_response(status, response_headers) return [output] |
啟動uwsgi
1
|
uwsgi -x /etc/uwsgi/apps-enabled/default .xml --daemonize /var/log/uwsgi/app/default .log |
uwsgi 的參數(shù):
-M 開啟Master進程
-p 4 開啟4個進程
-s 使用的端口或者socket地址
-d 使用daemon的方式運行, 注意, 使用-d后, 需要加上log文件地址, 比如-d /var/log/uwsgi.log
-R 10000 開啟10000個進程后, 自動respawn下
-t 30 設(shè)置30s的超時時間, 超時后, 自動放棄該鏈接
–limit-as 32 將進程的總內(nèi)存量控制在32M
-x 使用配置文件模式
并發(fā)4個線程
1
|
uwsgi -s :9090 -w myapp -p 4 |
主控制線程+4個線程
1
|
uwsgi -s :9090 -w myapp -M -p 4 |
執(zhí)行超過30秒的client直接放棄
1
|
uwsgi -s :9090 -w myapp -M -p 4 -t 30 |
限制內(nèi)存空間128M
1
|
uwsgi -s :9090 -w myapp -M -p 4 -t 30 --limit-as 128 |
服務(wù)超過10000個req自動respawn
1
|
uwsgi -s :9090 -w myapp -M -p 4 -t 30 --limit-as 128 -R 10000 |
后臺運行等
1
|
uwsgi -s :9090 -w myapp -M -p 4 -t 30 --limit-as 128 -R 10000 -d uwsgi.log |
除了直接用uwsgi命令啟動外,還可以用init.d下的腳本啟動, 不過需先修 改/etc/default/u wsgi中默認配置文件的路徑,然后通過/etc/init.d/uwsgi start啟動
1
2
|
#INHERITED_CONFIG=/usr/share/uwsgi/conf/default.ini INHERITED_CONFIG=/etc/uwsgi/apps-enabled/default.xml |
啟動nginx
1
|
/etc/init .d /nginx start |
效果如下:
測試uwsgi是否可用
測試腳本test.py
1
2
3
4
|
#!/usr/bin/python def application(env,start_response): start_response( '200 OK' ,[( 'Content_Type' , 'text/html' )]) return "Congraduation!!! uWSGI Testing OK!!! |
1
2
|
#啟動web server uwsgi --http :9090 --wsgi- file test .py |
瀏覽器輸入IP:端口:192.168.1.99:9090
可以看到”Congraduation!!! uWSGI Testing OK!!!”
小結(jié)
uwsgi 實際上也是一個 http 服務(wù)器,只不過它只面向 python 網(wǎng)絡(luò)應(yīng)用程序。雖然 uwsgi 也是 http 服務(wù)器,但是卻不能直接使用它部署 python web 應(yīng)用程序,否則會出錯。
在本文中,uwsgi 所扮演的的角色是后端 http 服務(wù)器,nginx 扮演的角色是前端 http 服務(wù)器,hello.py 是客戶端應(yīng)用程序。 用戶從網(wǎng)頁瀏覽器中發(fā)出請求,nginx 服務(wù)器收到請求后,會通過它的 uwsgi 模塊將用戶的請求轉(zhuǎn)發(fā)給 uwsgi 服務(wù)器,uwsgi 服務(wù)器處理完畢后將結(jié)果返回給 nginx,瀏覽器將最終的結(jié)果展現(xiàn)給用戶。