今天来看下基于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