django nginx部署_django apache部署

2022-10-01 15:25:09 浏览数 (1)

大家好,又见面了,我是你们的朋友全栈君。

上传完整django项目文件到服务器

sftp ftp lrzsz都可以上传文件到服务器,看自己 我django项目叫yunwei,主要app是rabc和web,整个项目放/opt/下 如下:

代码语言:javascript复制
[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安装

如果用到的python版本是2,不需要重新安装,如果是3,那么需要重新安装,参照:centos安装python3.8

django相关库的安装

#在原项目处导出django项目安装的库存入文件

代码语言:javascript复制
pip freeze > install.txt

把文件放到需要部署的服务器上,并安装文件内的包 #在待部署的服务器上执行

代码语言:javascript复制
pip install -r install.txt

nginx安装&配置(处理静态请求和代理动态请求到uwsgi)

nginx安装参照:linux安装nginx nginx配置文件如下

代码语言:javascript复制
[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文件
    	}

}

uwsgi安装&配置

代码语言:javascript复制
pip install uwsgi

在django的项目目录下/opt/yunwei/创建一个uwsgi的目录用于存放uwsgi相关的文件。

代码语言:javascript复制
cd /opt/yunwei/ && mkdir uwsgi
touch uwsgi/uwsgi.ini

#创建配置文件

代码语言:javascript复制
[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

标题关闭setting.py的DEBUG模式

代码语言:javascript复制
vim /opt/yunwei/yunwei/setting.py

DEBUG = True #改为 DEBUG = False

#debug模式为True时,django会自己处理static的静态请求,现在是nginx去处理这些请求,故为False

做完上述步骤,只需要启动uwsgi和nginx即可,通过nginx listen端口去访问

代码语言:javascript复制
#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去杀掉进程

代码语言:javascript复制
#启动nginx
nginx
#重启
nginx -s reload
#关闭
nginx -s stop
#检测配置文件是否正确
nginx -t

搞定,作此记录。

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 举报,一经查实,本站将立刻删除。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/194726.html原文链接:https://javaforall.cn

0 人点赞