linux下通过Nginx + uWSGI 部署Django项目

linux下通过Nginx + uWSGI 部署Django项目

一、安装Nginx

参见文章《Centos7下安装Nginx》

二、安装uWSGI

参见文章《centos7安装和配置uWSGI》

三、测试Django是否可以正常启动

首先要先确保Django项目可以在linux环境下正常启动访问。
用如下命令看是否可以正常启动

python manage.py runserver 127.0.0.1:8000\

不能启动可以参考文章《linux下启动Django项目遇到的问题》

四、配置uWSGI

  • 修改配置文件

Django创建myweb项目时,在子目录myweb下已经帮我们生成的wsgi.py文件。所以,我们只需要在wsgi.py所在文件夹下再创建uwsgi.ini配置文件即可,当然,uwsgi支持多种类型的配置文件,如xml,ini等。此处,使用ini类型的配置。

# uwsgi file
[uwsgi]
# Django-related settings
socket = :8008
# the base directory (full path)
chdir           = /home/web/bootsmodel1
# Django s wsgi file
# 加载一个WSGI模块,这里加载mysite/wsgi.py这个模块
module          = mysite.wsgi 
# process-related settings
# master
master          = true
# maximum number of worker processes
processes       = 4
# ... with appropriate permissions - may be needed
# chmod-socket    = 664
# clear environment on exit
vacuum          = true

socket:端口号,修改下不要冲突了。
chdir:Django项目的路径,到最外面一层文件夹即可。
只需要修改我这两个地方即可。

另附配置文件详解:

master = true 
#启动主进程,来管理其他进程,其它的uwsgi进程都是这个master进程的子进程,如果kill这个master进程,相当于重启所有的uwsgi进程。
chdir = /web/www/mysite 
#在app加载前切换到当前目录, 指定运行目录
module = mysite.wsgi 
#加载一个WSGI模块,这里加载mysite/wsgi.py这个模块
py-autoreload=1  
#监控python模块mtime来触发重载 (只在开发时使用)
lazy-apps=true  
#在每个worker而不是master中加载应用
socket = /test/myapp.sock 
#指定socket文件,也可以指定为127.0.0.1:9000,这样就会监听到网络套接字
processes = 2 #启动2个工作进程,生成指定数目的worker/进程
buffer-size = 32768 
#设置用于uwsgi包解析的内部缓存区大小为64k。默认是4k。
daemonize = /var/log/myapp_uwsgi.log 
#使进程在后台运行,并将日志打到指定的日志文件或者udp服务器
log-maxsize = 5000000 #设置最大日志文件大小
disable-logging = true #禁用请求日志记录
vacuum = true #当服务器退出的时候自动删除unix socket文件和pid文件。
listen = 120 #设置socket的监听队列大小(默认:100)
pidfile = /var/run/uwsgi.pid #指定pid文件
enable-threads = true 
#允许用内嵌的语言启动线程。这将允许你在app程序中产生一个子线程
reload-mercy = 8 
#设置在平滑的重启(直到接收到的请求处理完才重启)一个工作子进程中,等待这个工作结束的最长秒数。这个配置会使在平滑地重启工作子进程中,如果工作进程结束时间超过了8秒就会被强行结束(忽略之前已经接收到的请求而直接结束)
max-requests = 5000 
#为每个工作进程设置请求数的上限。当一个工作进程处理的请求数达到这个值,那么该工作进程就会被回收重用(重启)。你可以使用这个选项来默默地对抗内存泄漏
limit-as = 256 
#通过使用POSIX/UNIX的setrlimit()函数来限制每个uWSGI进程的虚拟内存使用数。这个配置会限制uWSGI的进程占用虚拟内存不超过256M。如果虚拟内存已经达到256M,并继续申请虚拟内存则会使程序报内存错误,本次的http请求将返回500错误。
harakiri = 60 
#一个请求花费的时间超过了这个harakiri超时时间,那么这个请求都会被丢弃,并且当前处理这个请求的工作进程会被回收再利用(即重启)

 

  • 启动uWSGI

进入之前所建配置文件uwsgi.ini所在的目录下,执行如下命令,不报错的话说明启动成功。

uwsgi --ini uwsgi.ini

这个命令关闭shell窗口的话,uwsgi就会关闭,所以可以使用后台运行命令,如下:

nohup uwsgi --ini uwsgi.ini &
  • 关闭uWSGI

关闭uWSGI命令

killall -9 uwsgi

五、配置Nginx

  • 配置Nginx

再接下来要做的就是修改nginx.conf配置文件。打开/etc/nginx/nginx.conf文件,修改如下内容

server {
    listen         8088; 
    server_name    127.0.0.1 
    charset UTF-8;
    access_log      /var/log/nginx/myweb_access.log;
    error_log       /var/log/nginx/myweb_error.log;

    client_max_body_size 75M;

    location / { 
        include uwsgi_params;
        uwsgi_pass 127.0.0.1:8000;
        uwsgi_read_timeout 2;
    }   
    location /static {
        expires 30d;
        autoindex on; 
        add_header Cache-Control private;
        alias /home/myweb/static/;#Django项目静态文件路径
     }
 }

listen:指定的是nginx代理uwsgi对外的端口号。
server_name:这里可以设置成你自己的域名,或者本机默认ip。

而nginx与uwsgi产生关系的就是通过下面两行配置。

include uwsgi_params;
uwsgi_pass 127.0.0.1:8000;

include 必须指定为uwsgi_params;
而uwsgi_pass指的本机IP的端口与uwsgi.ini配置文件中的必须一致。

 

  • 启动Nginx

这个时候启动Nginx,就可以使用Nginx的端口访问Django项目程序。
http://127.0.0.1:8088/

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值