您好,登录后才能下订单哦!
本篇内容介绍了“centos+nginx+uwsgi部署django项目上线的方法”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
我django项目叫yunwei,主要app是rabc和web,整个项目放/opt/下
如下:
[root@test-code opt]# ls django_virt nginx redis redis-6.2.6 yunwei [root@test-code opt]# ls yunwei/ manage.py rbac static templates uwsgi web yunwei [root@test-code opt]# ls yunwei/uwsgi/ cut_log.sh log uwsgi.ini uwsgi.log uwsgi.pid uwsgi.sock [root@test-code opt]#
/opt/yunwei/就是我的django项目的根目录,manage.py就是在这个目录下,/opt/yunwei/下有一个同名子目录yunwei,下面有一个setting.py的配置文件
如果用到的python版本是2,不需要重新安装,如果是3,那么需要重新安装
#在原项目处导出django项目安装的库存入文件 pip freeze > install.txt
把文件放到需要部署的服务器上,并安装文件内的包
#在待部署的服务器上执行 pip install -r install.txt
nginx安装参照:linux安装nginx
nginx配置文件如下
[root@test-code opt]# cat /opt/nginx/conf.d/django.conf server { listen 8881; server_name localhost; server_tokens off; location /static { root /opt/yunwei; index index.html index.htm; } location / { include uwsgi_params; #nginx加载uwsgi模块 uwsgi_buffer_size 16k; uwsgi_busy_buffers_size 24k; #如果你后端的需要超过60秒时间处理请求,那么一定要加上下面三个超时时间的设置,不然60s之后nginx断开链接报超时 uwsgi_send_timeout 600; # 指定向uWSGI传送请求的超时时间,完成握手后向uWSGI传送请求的超时时间。 uwsgi_connect_timeout 600; # 指定连接到后端uWSGI的超时时间。 uwsgi_read_timeout 600; # 指定接收uWSGI应答的超时时间,完成握手后接收uWSGI应答的超时时间。 uwsgi_pass unix:/opt/yunwei/uwsgi/uwsgi.sock; #nginx对应的uwsgi socket文件 } }
pip install uwsgi
在django的项目目录下/opt/yunwei/创建一个uwsgi的目录用于存放uwsgi相关的文件。
cd /opt/yunwei/ && mkdir uwsgi touch uwsgi/uwsgi.ini
创建配置文件
[root@test-code yunwei]# cat uwsgi/uwsgi.ini [uwsgi] #django项目的根目录,即manage.py所在的目录 chdir=/opt/yunwei #django项目的wsgi,yuwnei的项目名 module=yunwei.wsgi:application socket=/opt/yunwei/uwsgi/uwsgi.sock #这里是我的python虚拟环境,可以不配置 home=/opt/django_virt #进程数 workers=5 #pid文件路径 pidfile=/opt/yunwei/uwsgi/uwsgi.pid #IP端口 socket = 0.0.0.0:8000 master=true #退出清理文件 vacuum=true #启用线程 enable-threads=true #序列化接受的内容,如果可能的话 thunder-lock=true #设置自中断时间,如果后端处理一些请求时间比较长,这个一定要设置大一点 harakiri=3600 # socket-timeout=3600 #这个是和nginx搭配部署时的设置 http-timeout=3600 #这个是单独部署时的设置 #设置缓冲 post-buffering=65535 buffer-size = 6553600 #后台守护方式运行,日志路径 daemonize=/opt/yunwei/uwsgi/uwsgi.log
vim /opt/yunwei/yunwei/setting.py DEBUG = True #改为 DEBUG = False
debug模式为True时,django会自己处理static的静态请求,现在是nginx去处理这些请求,故为False
做完上述步骤,只需要启动uwsgi和nginx即可,通过nginx listen端口去访问
#uwsgi 启动命令 uwsgi --ini /opt/yunwei/uwsgi/uwsgi.ini #uwsgi 重启命令 uwsgi --reload /opt/yunwei/uwsgi/uwsgi.ini
uwsgi的日志文件在/opt/yunwei/uwsgi/uwsgi.log处
可以通过 ss -tnulp | grep uwsgi 去kill -9 进程ID去杀掉进程
#启动nginx nginx #重启 nginx -s reload #关闭 nginx -s stop #检测配置文件是否正确 nginx -t
“centos+nginx+uwsgi部署django项目上线的方法”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。