今天來看下基于Django開發的應用如何在Centos6環境部署
系統環境:Centos6.5 x64
軟體版本:Django 1.9.5 、uwsgi-2.0.13.1
nginx 安裝配置(略)請見:http://tchuairen.blog.51cto.com/3848118/1771597
一、安裝uwsgi
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
<code># 安裝有兩種方式</code>
<code># 1、源碼安裝</code>
<code># 從官網下載下傳uwsgi源碼包 : http://uwsgi-docs.readthedocs.io/en/latest/</code>
<code># 安裝編譯需要的程式包</code>
<code>yum </code><code>install</code> <code>libxml2-devel libxml2 -y</code>
<code>cd</code> <code>uwsgi-2.0.13.1</code>
<code>python setup.py </code><code>install</code>
<code># 2、使用工具直接安裝( pip or easy_install )</code>
<code>pip </code><code>install</code> <code>uwsgi</code>
<code># 如果沒有mysql庫,為保證Django正常工作,需要安裝mysql庫</code>
<code>pip </code><code>install</code> <code>mysql-python</code>
二、測試uwsgi
準備測試檔案
test1.py
<code>def</code> <code>application(env, start_response):</code>
<code> </code><code>start_response(</code><code>'200 OK'</code><code>,[(</code><code>'Content-Type'</code><code>,</code><code>'text/html'</code><code>)])</code>
<code> </code><code>return</code> <code>"uwsgi ok!"</code>
指令執行
<code>uwsgi --http :8001 --wsgi-</code><code>file</code> <code>test1.py</code>
<code># 浏覽器測試 IP:8001</code>
三、配置uwsgi+Django
建立Django wsgi檔案(路徑和manage.py檔案同級目錄,一般安裝了Django會自帶。)
wsgi.py
<code>import</code> <code>os</code>
<code>import</code> <code>sys</code>
<code>from</code> <code>django.core.wsgi </code><code>import</code> <code>get_wsgi_application</code>
<code>os.environ.setdefault(</code><code>"DJANGO_SETTINGS_MODULE"</code><code>, </code><code>"devops.settings"</code><code>)</code>
<code>application </code><code>=</code> <code>get_wsgi_application()</code>
建立 uwsgi 服務主配置檔案
uwsgi.ini
22
23
24
25
26
27
28
29
30
31
32
33
34
35
<code>[uwsgi]</code>
<code>uid = www </code><code># 設定啟動的使用者組</code>
<code>gid = www</code>
<code>chdir = </code><code>/alidata/www/fdcode/devops</code> <code># 指定項目目錄</code>
<code>module = wsgi </code><code># 加載wsgi.py子產品</code>
<code>master = </code><code>true</code> <code># 啟動主程序,一般設定true或 1</code>
<code>processes = 2 </code><code># 設定啟動的程序數</code>
<code>listen = 100 </code><code># 設定socket監聽隊列大小,超出隊列的請求将會被拒絕</code>
<code>;socket = </code><code>/var/run/uwsgi/uwsgi</code><code>.sock </code><code># 設定socket監聽</code>
<code>socket = :9090 </code><code># 設定端口監聽</code>
<code>pidfile = </code><code>/var/run/uwsgi/uwsgi</code><code>.pid </code><code># 指定pid檔案</code>
<code>vacuum = </code><code>true</code> <code># 當伺服器退出的時候自動删除unixsocket檔案和pid檔案。</code>
<code>enable</code><code>-threads = </code><code>true</code> <code># 允許用内嵌的語言啟動線程。這将允許你在app程式中産生一個子線程</code>
<code>buffer-size = 32768 </code><code># 設定用于uwsgi包解析的内部緩存區大小為64k。預設是4k。</code>
<code>reload-mercy = 8 </code><code># 設定在平滑的重新開機(直到接收到的請求處理完才重新開機)一個工作子程序中,等待這個工作結束的最長秒數。這個配置會使在平滑地重新開機工作子程序中,如果工作程序結束時間超過了8秒就會被強行結束(忽略之前已經接收到的請求而直接結束)</code>
<code>max-requests = 5000 </code><code># 為每個工作程序設定請求數的上限。當一個工作程序處理的請求數達到這個值,那麼該工作程序就會被回收重用(重新開機)。你可以使用這個選項來默默地對抗記憶體洩漏</code>
<code>limit-as = 512 </code><code># 通過使用POSIX/UNIX的setrlimit()函數來限制每個uWSGI程序的虛拟記憶體使用數。這個配置會限制uWSGI的程序占用虛拟記憶體不超過256M。如果虛拟記憶體已經達到256M,并繼續申請虛拟記憶體則會使程式報記憶體錯誤,本次的http請求将傳回500錯誤。</code>
<code>harakiri = 60 </code><code># 一個請求花費的時間超過了這個harakiri逾時時間,那麼這個請求都會被丢棄,并且目前處理這個請求的工作程序會被回收再利用(即重新開機)</code>
<code>daemonize = </code><code>/alidata/log/uwsgi/uwsgi_server</code><code>.log </code><code># 使程序在背景運作,并将日志打到指定的日志檔案或者udp伺服器</code>
啟動服務
uwsgi --ini uwsgi.ini
另一種配置方式
當.ini配置檔案不好用時,也可以使用xml配置檔案
uwsgi-socket.xml
<code><uwsgi></code>
<code> </code><code><socket>127.0.0.1:8001<</code><code>/socket</code><code>> </code><code># 設定監聽位址:端口,如果監聽全部位址則可以這樣寫 :8001 </code>
<code> </code><code><chdir></code><code>/alidata/www/dev/devops</code><code><</code><code>/chdir</code><code>> </code><code># 設定項目目錄</code>
<code> </code><code><module>wsgi<</code><code>/module</code><code>> </code><code># 加載Django的 wsgi.py 子產品</code>
<code> </code><code><processes>2<</code><code>/processes</code><code>> </code><code># 設定程序數</code>
<code> </code><code><daemonize>uwsgi.log<</code><code>/daemonize</code><code>> </code><code># 設定日志檔案路徑</code>
<code><</code><code>/uwsgi</code><code>></code>
uwsgi -x uwsgi-socket.xml
Nginx 配置檔案
django_nginx.conf
<code>server {</code>
<code> </code><code>listen 80;</code>
<code> </code><code>server_name abc.xxx.com;</code>
<code> </code><code>location / {</code>
<code> </code><code>rewrite ^/$ </code><code>/ops01/login/</code> <code>last;</code>
<code> </code><code>include uwsgi_params;</code>
<code> </code><code>uwsgi_pass 127.0.0.1:9090;</code>
<code> </code><code>}</code>
<code> </code><code>location </code><code>/static</code> <code>{</code>
<code> </code><code>alias</code> <code>/alidata/www/fdcode/devops/static</code><code>;</code>
<code>}</code>
uwsgi各項配置參數詳解,請參考 : http://www.cnblogs.com/zhouej/archive/2012/03/25/2379646.html
本文轉自qw87112 51CTO部落格,原文連結:http://blog.51cto.com/tchuairen/1831281