今天来看下基于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 | # 安装有两种方式 # 1、源码安装 # 从官网下载uwsgi源码包 : http://uwsgi-docs.readthedocs.io/en/latest/ # 安装编译需要的程序包 yum install libxml2-devel libxml2 -y cd uwsgi-2.0.13.1 python setup.py install # 2、使用工具直接安装( pip or easy_install ) pip install uwsgi # 如果没有mysql库,为保证Django正常工作,需要安装mysql库 pip install mysql-python |
二、测试uwsgi
准备测试文件
test1.py
1 2 3 | def application(env, start_response): start_response( '200 OK' ,[( 'Content-Type' , 'text/html' )]) return "uwsgi ok!" |
命令执行
1 2 3 | uwsgi --http :8001 --wsgi- file test1.py # 浏览器测试 IP:8001 |
三、配置uwsgi+Django
创建Django wsgi文件(路径和manage.py文件同级目录,一般安装了Django会自带。)
wsgi.py
1 2 3 4 5 6 7 8 | import os import sys from django.core.wsgi import get_wsgi_application os.environ.setdefault( "DJANGO_SETTINGS_MODULE" , "devops.settings" ) application = get_wsgi_application() |
创建 uwsgi 服务主配置文件
uwsgi.ini
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | [uwsgi] uid = www # 设置启动的用户组 gid = www chdir = /alidata/www/fdcode/devops # 指定项目目录 module = wsgi # 加载wsgi.py模块 master = true # 启动主进程,一般设置true或 1 processes = 2 # 设置启动的进程数 listen = 100 # 设置socket监听队列大小,超出队列的请求将会被拒绝 ;socket = /var/run/uwsgi/uwsgi .sock # 设置socket监听 socket = :9090 # 设置端口监听 pidfile = /var/run/uwsgi/uwsgi .pid # 指定pid文件 vacuum = true # 当服务器退出的时候自动删除unixsocket文件和pid文件。 enable -threads = true # 允许用内嵌的语言启动线程。这将允许你在app程序中产生一个子线程 buffer-size = 32768 # 设置用于uwsgi包解析的内部缓存区大小为64k。默认是4k。 reload-mercy = 8 # 设置在平滑的重启(直到接收到的请求处理完才重启)一个工作子进程中,等待这个工作结束的最长秒数。这个配置会使在平滑地重启工作子进程中,如果工作进程结束时间超过了8秒就会被强行结束(忽略之前已经接收到的请求而直接结束) max-requests = 5000 # 为每个工作进程设置请求数的上限。当一个工作进程处理的请求数达到这个值,那么该工作进程就会被回收重用(重启)。你可以使用这个选项来默默地对抗内存泄漏 limit-as = 512 # 通过使用POSIX/UNIX的setrlimit()函数来限制每个uWSGI进程的虚拟内存使用数。这个配置会限制uWSGI的进程占用虚拟内存不超过256M。如果虚拟内存已经达到256M,并继续申请虚拟内存则会使程序报内存错误,本次的http请求将返回500错误。 harakiri = 60 # 一个请求花费的时间超过了这个harakiri超时时间,那么这个请求都会被丢弃,并且当前处理这个请求的工作进程会被回收再利用(即重启) daemonize = /alidata/log/uwsgi/uwsgi_server .log # 使进程在后台运行,并将日志打到指定的日志文件或者udp服务器 |
启动服务
uwsgi --ini uwsgi.ini
另一种配置方式
当.ini配置文件不好用时,也可以使用xml配置文件
uwsgi-socket.xml
1 2 3 4 5 6 7 | <uwsgi> <socket>127.0.0.1:8001< /socket > # 设置监听地址:端口,如果监听全部地址则可以这样写 :8001 <chdir> /alidata/www/dev/devops < /chdir > # 设置项目目录 <module>wsgi< /module > # 加载Django的 wsgi.py 模块 <processes>2< /processes > # 设置进程数 <daemonize>uwsgi.log< /daemonize > # 设置日志文件路径 < /uwsgi > |
启动服务
uwsgi -x uwsgi-socket.xml
Nginx 配置文件
django_nginx.conf
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | server { listen 80; server_name abc.xxx.com; location / { rewrite ^/$ /ops01/login/ last; include uwsgi_params; uwsgi_pass 127.0.0.1:9090; } location /static { alias /alidata/www/fdcode/devops/static ; } } |
uwsgi各项配置参数详解,请参考 : http://www.cnblogs.com/zhouej/archive/2012/03/25/2379646.html