Django使用uwsgi和nginx进行手动部署

在Django项目中使用uWSGI和Nginx进行部署是一种常见的生产环境配置。以下是一个详细的步骤指南,帮助你完成这个过程。

前提条件

  1. 有一个已经开发好的Django项目。
  2. 服务器已安装Python、pip、Nginx和uWSGI。
  3. 有一个有效的域名(可选,但推荐)。

步骤一:准备Django项目

  1. 收集静态文件:

    在项目根目录下运行以下命令,将静态文件收集到指定的目录(如staticfiles)。

    python manage.py collectstatic

设置ALLOWED_HOSTS

settings.py中,添加你的域名或服务器IP地址到ALLOWED_HOSTS列表。

复制代码
ALLOWED_HOSTS = ['yourdomain.com', 'your_server_ip']

前后端分离,且部署在一台服务器上时,可以写 127.0.0.1

步骤二:安装和配置uWSGI

安装uWSGI:

使用pip安装uWSGI。

复制代码
pip install uwsgi

创建uWSGI配置文件:

创建一个uWSGI配置文件(如myproject.ini),内容如下:

uwsgi

module = djangoProject.wsgi:application

master = true

workers=2

threads=2

socket = /opt/project/djangoProject/djangoProject.sock

chmod-socket = 777

chdir=/opt/project/djangoProject

daemonize=/opt/project/djangoProject/djangoProject.log

注意:项目目录为 /opt/project/djangoProject/

启动uWSGI:

使用uWSGI配置文件启动服务。

复制代码
uwsgi --ini myproject.ini

注意:如果找不到uwsgi的话,它在Python安装目录的bin里面,可以使用绝对路径执行或者添加软连接后在任意路径执行

执行成功后,会看到好几个 worker启动了...

配置nginx:

只需要更新server部分的内容:

复制代码
server {
                # nginx启动监听的端口
        listen       8000;
                
        # 可以是localhost和可以是本机ip地址,如果要给公司其他同事的电脑可以访问,需要 配置为本机的ip地址
        server_name  127.0.0.1;

                location / {
                        include uwsgi_params;
                        # 配置uwsgi里面的sock文件路径
                        uwsgi_pass unix:/opt/project/djangoProject/djangoProject.sock;
                }
       
    }

如果访问时502的话,请把nginx.conf上面的err_log放开,然后在 nginx的logs目录下可以查看报错日志!

此时,访问 127.0.0.1:8000 即可访问web页面了!

相关推荐
颜酱18 分钟前
图结构完全解析:从基础概念到遍历实现
javascript·后端·算法
喵手37 分钟前
Python爬虫实战:旅游数据采集实战 - 携程&去哪儿酒店机票价格监控完整方案(附CSV导出 + SQLite持久化存储)!
爬虫·python·爬虫实战·零基础python爬虫教学·采集结果csv导出·旅游数据采集·携程/去哪儿酒店机票价格监控
Coder_Boy_41 分钟前
技术让开发更轻松的底层矛盾
java·大数据·数据库·人工智能·深度学习
2501_9449347342 分钟前
高职大数据技术专业,CDA和Python认证优先考哪个?
大数据·开发语言·python
helloworldandy1 小时前
使用Pandas进行数据分析:从数据清洗到可视化
jvm·数据库·python
肖永威2 小时前
macOS环境安装/卸载python实践笔记
笔记·python·macos
TechWJ3 小时前
PyPTO编程范式深度解读:让NPU开发像写Python一样简单
开发语言·python·cann·pypto
数据知道3 小时前
PostgreSQL 故障排查:如何找出数据库中最耗时的 SQL 语句
数据库·sql·postgresql
qq_12498707533 小时前
基于SSM的动物保护系统的设计与实现(源码+论文+部署+安装)
java·数据库·spring boot·毕业设计·ssm·计算机毕业设计
枷锁—sha3 小时前
【SRC】SQL注入WAF 绕过应对策略(二)
网络·数据库·python·sql·安全·网络安全