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页面了!

相关推荐
幽兰的天空20 分钟前
Python 中的模式匹配:深入了解 match 语句
开发语言·python
远歌已逝1 小时前
维护在线重做日志(二)
数据库·oracle
qq_433099402 小时前
Ubuntu20.04从零安装IsaacSim/IsaacLab
数据库
Dlwyz2 小时前
redis-击穿、穿透、雪崩
数据库·redis·缓存
网易独家音乐人Mike Zhou4 小时前
【卡尔曼滤波】数据预测Prediction观测器的理论推导及应用 C语言、Python实现(Kalman Filter)
c语言·python·单片机·物联网·算法·嵌入式·iot
安静读书4 小时前
Python解析视频FPS(帧率)、分辨率信息
python·opencv·音视频
工业甲酰苯胺4 小时前
Redis性能优化的18招
数据库·redis·性能优化
没书读了5 小时前
ssm框架-spring-spring声明式事务
java·数据库·spring
小二·5 小时前
java基础面试题笔记(基础篇)
java·笔记·python
i道i6 小时前
MySQL win安装 和 pymysql使用示例
数据库·mysql