如何进行Django项目的线上部署?
- 内容介绍
- 文章标签
- 相关推荐
本文共计538个文字,预计阅读时间需要3分钟。
1. 线上部署一般会使用https方式进行,而本身Django框架不支持,因此需要。
1.安装扩展:`pip install django-extensions django-werkzeug-debugger runserver pyOpenSSL`
2.在`settings.py`文件中添加配置项。
1.线上部署一般会使用0.0.0.0:8000的django服务了
但是这种这能监听一个接口,提供服务, django3.0+提供了异步特性, 同时支持uvicorn的部署方式
2.supervisor+uvicorn+nginx部署
1)安装uvicorn
uvicorn采用了uvloop 用Cython改写了python里面asyncio的时间循环, 将asyncio的效率提高了4倍以上
pip3 install uvicorn运行项目方式:
uvicorn [项目主目录].asgi.application 即可2)安装supervisor, 这个的安装我之前的文章中也有详细的说明, 这里就略过
添加项目配置项:
[fcgi-program:xxx]socket=tcp://localhost:8000
directory=/opt/xxx/
command=/opt/xxx/env/bin/uvicorn --fd 0 xxx.asgi:application --ssl-certfile=/etc/certs/xxx.com_bundle.crt --ssl-keyfile=/etc/certs/xxx.com.key
numprocs=4
autostart=true
process_name=service-%(process_num)d
stdout_logfile=/var/log/supervisord/xxx.log ; stdout log path, NONE for none; default AUTO
stdout_logfile_maxbytes=100MB ; max # logfile bytes b4 rotation (default 50MB)
stdout_logfile_backups=10 ; # of stdout logfile backups (0 means none, default 10)
stderr_logfile=/var/log/supervisord/xxx_error.log ; stderr log path, NONE for none; default AUTO
stderr_logfile_maxbytes=100MB ; max # logfile bytes b4 rotation (default 50MB)
stderr_logfile_backups=10 ; # of stderr logfile backups (0 means none, default 10)
说明:
socket为对外暴露的接口 可以是unix 也可以是一个网络端口 端口的形式可以见官方文档
command为执行命令
directory为项目路径
numprocs是处理器个数
process_name是处理进程的名称
添加完成之后, 更新supervisor
supervisorctl update # 更新配置supervisorctl start uvicorn:*
supervisorctl stop uvicorn:*
supervisorctl restart uvicorn:*
*的作用是所有进程:
start Start a process
start :* Start all processes in a group
start Start multiple processes or groups
start all Start all processes
3)nginx配置
配置文件中添加反向代理
1)127.0.0.1:8000;
}
}
2)127.0.0.1:9000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
location ~ ^/(admin|user|oidc|backend|astatic) {
proxy_pass_header Server;
proxy_set_header Host $127.0.0.1:8000;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}
本文共计538个文字,预计阅读时间需要3分钟。
1. 线上部署一般会使用https方式进行,而本身Django框架不支持,因此需要。
1.安装扩展:`pip install django-extensions django-werkzeug-debugger runserver pyOpenSSL`
2.在`settings.py`文件中添加配置项。
1.线上部署一般会使用0.0.0.0:8000的django服务了
但是这种这能监听一个接口,提供服务, django3.0+提供了异步特性, 同时支持uvicorn的部署方式
2.supervisor+uvicorn+nginx部署
1)安装uvicorn
uvicorn采用了uvloop 用Cython改写了python里面asyncio的时间循环, 将asyncio的效率提高了4倍以上
pip3 install uvicorn运行项目方式:
uvicorn [项目主目录].asgi.application 即可2)安装supervisor, 这个的安装我之前的文章中也有详细的说明, 这里就略过
添加项目配置项:
[fcgi-program:xxx]socket=tcp://localhost:8000
directory=/opt/xxx/
command=/opt/xxx/env/bin/uvicorn --fd 0 xxx.asgi:application --ssl-certfile=/etc/certs/xxx.com_bundle.crt --ssl-keyfile=/etc/certs/xxx.com.key
numprocs=4
autostart=true
process_name=service-%(process_num)d
stdout_logfile=/var/log/supervisord/xxx.log ; stdout log path, NONE for none; default AUTO
stdout_logfile_maxbytes=100MB ; max # logfile bytes b4 rotation (default 50MB)
stdout_logfile_backups=10 ; # of stdout logfile backups (0 means none, default 10)
stderr_logfile=/var/log/supervisord/xxx_error.log ; stderr log path, NONE for none; default AUTO
stderr_logfile_maxbytes=100MB ; max # logfile bytes b4 rotation (default 50MB)
stderr_logfile_backups=10 ; # of stderr logfile backups (0 means none, default 10)
说明:
socket为对外暴露的接口 可以是unix 也可以是一个网络端口 端口的形式可以见官方文档
command为执行命令
directory为项目路径
numprocs是处理器个数
process_name是处理进程的名称
添加完成之后, 更新supervisor
supervisorctl update # 更新配置supervisorctl start uvicorn:*
supervisorctl stop uvicorn:*
supervisorctl restart uvicorn:*
*的作用是所有进程:
start Start a process
start :* Start all processes in a group
start Start multiple processes or groups
start all Start all processes
3)nginx配置
配置文件中添加反向代理
1)127.0.0.1:8000;
}
}
2)127.0.0.1:9000;
proxy_set_header Host $host;
proxy_set_header X-Real-IP $remote_addr;
proxy_set_header REMOTE-HOST $remote_addr;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
location ~ ^/(admin|user|oidc|backend|astatic) {
proxy_pass_header Server;
proxy_set_header Host $127.0.0.1:8000;
proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
}
}

