天天看点

nginx + uwsgi + Django 应用部署

今天来看下基于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>&lt;uwsgi&gt;</code>

<code>    </code><code>&lt;socket&gt;127.0.0.1:8001&lt;</code><code>/socket</code><code>&gt;          </code><code># 设置监听地址:端口,如果监听全部地址则可以这样写 :8001 </code>

<code>    </code><code>&lt;chdir&gt;</code><code>/alidata/www/dev/devops</code><code>&lt;</code><code>/chdir</code><code>&gt;   </code><code># 设置项目目录</code>

<code>    </code><code>&lt;module&gt;wsgi&lt;</code><code>/module</code><code>&gt;                    </code><code># 加载Django的 wsgi.py 模块</code>

<code>    </code><code>&lt;processes&gt;2&lt;</code><code>/processes</code><code>&gt;                 </code><code># 设置进程数</code>

<code>    </code><code>&lt;daemonize&gt;uwsgi.log&lt;</code><code>/daemonize</code><code>&gt;         </code><code># 设置日志文件路径</code>

<code>&lt;</code><code>/uwsgi</code><code>&gt;</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

继续阅读