Supervisor+gunicorn+nginx部署django


内容借鉴: https://www.lylinux.net/article/2019/8/5/58.html#_1

使用工具

FinalShell

准备工作

1. 升级系统

sudo apt update
sudo apt upgrade -y

2. 升级完成后,重启系统

sudo reboot

3. 安装依赖

sudo apt install mysql-server -y #安装mysql
sudo apt install python3-dev python3-pip python-pip memcached virtualenv -y #安装pip和memcached
sudo apt install supervisor -y
sudo apt install nginx -y
sudo apt-get install python-dev default-libmysqlclient-dev #安装mysqlclient依赖
sudo apt-get install unzip  #解压工具

Mysql数据安装及配置

1. 配置mysql

sudo mysql_secure_installation

在这里插入图片描述

2.按下图,继续操作

在这里插入图片描述

3.测试数据库是否能登录

mysql -uroot -p  

退出登录,使用 Crtl+D

4.修改mysql默认字符集

文件地址:

/etc/mysql/conf.d/mysql.cnf

删除该文件的[mysql]行并贴入如下内容:

[mysqld]
character-set-server=utf8mb4
collation-server=utf8mb4_unicode_ci

[client]
default-character-set = utf8mb4

[mysql]
default-character-set = utf8mb4

保存退出后,重启数据库,执行命令:

sudo /etc/init.d/mysql restart

后续操作,进入数据库,创建数据表并导入数据.mysql教程

后端代码及配置

1.新建文件存放项目

在home目录下新建一个wwwroot文件夹存放项目(可自己建立存放地址)

cd /home
mkdir wwwroot
cd wwwroot

2.上传后端项目和解压项目

上传后端代码如图:
在这里插入图片描述
解压后端代码,到指定的文件夹

unzip dvadmin-backend.zip -d dvadmin

在这里插入图片描述

3.建立项目虚拟环境

进入项目

cd dvadmin

创建虚拟环境

virtualenv venv

启用虚拟环境

source venv/bin/activate

成功以后会出现(venv),类似于下图:
在这里插入图片描述

4.安装django项目依赖

pip install -i https://pypi.tuna.tsinghua.edu.cn/simple -r requirements.txt

5.收集静态文件

等待依赖完成以后,收集静态文件

 python manage.py collectstatic --no-input

6.测试项目是否正常运行

python manage.py runserver

创建gunicorn配置(可替换为daphne)

1.在虚拟环境下,安装

pip install gunicorn

2.新增配置文件

在项目根目录下新建gunicorn_start.sh文件
文件内容如下:

#!/bin/bash

NAME="dvadmin" #项目名
DJANGODIR=/home/wwwroot/dvadmin    #django项目路径
USER=root  # the user to run as  #用户
GROUP=root  # the group to run as #用户组
NUM_WORKERS=1 # how many worker processes should Gunicorn spawn
DJANGO_SETTINGS_MODULE=application.settings # which settings file should Django use
DJANGO_WSGI_MODULE=application.wsgi # WSGI module name

echo "Starting $NAME as `whoami`"

# Activate the virtual environment
cd $DJANGODIR
source /home/wwwroot/dvadmin/venv/bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPATH

# Create the run directory if it doesn't exist
RUNDIR=$(dirname $SOCKFILE)
test -d $RUNDIR || mkdir -p $RUNDIR

# Start your Django Unicorn
# Programs meant to be run under supervisor should not daemonize themselves (do not use --daemon)
exec /home/wwwroot/dvadmin/venv/bin/gunicorn  ${DJANGO_WSGI_MODULE}:application \
--name $NAME \
--workers $NUM_WORKERS \
--user=$USER --group=$GROUP \
--log-level=debug \
--log-file=-

3.增加可执行权限

chmod +x /home/wwwroot/dvadmin/gunicorn_start.sh

4.确认文件是否正确

在gunicorn_start.sh文件目录下,执行

./gunicorn_start.sh

在这里插入图片描述

如上图则成功,通过Ctrl+c终止运行

daphne安装与配置

1.在虚拟环境下安装daphne

pip install daphne

2.在项目根目录下新增配置文件daphne_start.sh

#!/bin/bash

USER=root  # the user to run as  #用户
GROUP=root  # the group to run as #用户组
NAME="bankend" #项目名
DJANGODIR=/home/wwwroot/backend
DJANGO_ASGI=application.asgi
DJANGO_SETTINGS_MODULE=application.settings

echo "Starting $NAME as `whoami`"

cd $DJANGODIR
source $DJANGODIR/venv/bin/activate
export DJANGO_SETTINGS_MODULE=$DJANGO_SETTINGS_MODULE
export PYTHONPATH=$DJANGODIR:$PYTHONPAT
daphne -b 0.0.0.0 -p 8000 ${DJANGO_ASGI}:application

3.设置文件权限

chmod +x /home/wwwroot/backend/daphne_start.sh

4.测试是否成功`

./daphne_start.sh

在这里插入图片描述

上传前端代码

1.上传前端代码

将前端代码上传到 /home/wwwroot文件夹

2.解压前端代码

unzip dist.zip -d dvadmin-ui

nginx配置

1.删除默认配置

sudo rm /etc/nginx/sites-enabled/default

2.后端配置

进入 /etc/nginx/sites-enabled/ 目录,建立后端配置文件

sudo vim /etc/nginx/sites-enabled/dvadmin.conf

后端文件配置内容

server {

    listen 8000;
    server_name localhost;
    root /home/wwwroot/dvadmin/;

    access_log /home/wwwroot/django_access.log;
    error_log /home/wwwroot/django_error.log;

    location /static/ {
        alias /home/wwwroot/dvadmin/collectedstatic/;
        expires max;
        access_log        off;
        log_not_found     off;
    }
    location /media {
        # 静态文件配置
        alias /home/wwwroot/dvadmin/media/;
        expires max;
    }
    location ~ \.py$ {
        return 403;
    }

    location / {
        proxy_set_header X-Real-IP $remote_addr;
        proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
        proxy_set_header Host $http_host;
        proxy_set_header X-NginX-Proxy true;
        proxy_redirect off;
        if (!-f $request_filename) {
            proxy_pass http://127.0.0.1:8000;
            break;
        }
    }
}

3.前端配置

建立一个前端配置文件,dvadmin-ui.conf

server {
    listen 80;
    server_name localhost; #有域名放域名,没域名就是 localhost

    location / {
        root /home/wwwroot/dvadmin-ui; #这里放前端项目目录地址
        index index.html;
    }
}

配置Supervisor

1.创建 Supervisor文件

sudo vim /etc/supervisor/conf.d/dvadmin.conf

2.文件内容如下:

[program:dvadmin]
command = /home/wwwroot/dvadmin/gunicorn_start.sh
user = root
autostart=true
autorestart=true

redirect_stderr = true
stdout_logfile = /home/wwwroot/djangoblog.log
stderr_logfile=/home/wwwroot/djangoblog.err

3.其他命令

sudo supervisorctl update #更新supervisorctl 
sudo supervisorctl reload  #重启supervisorctl 
sudo /etc/init.d/memcached restart  #重启缓存
sudo /etc/init.d/nginx restart #重启nginx

如果修改了代码,只需要上传更新覆盖代码后执行:

sudo supervisorctl update
sudo /etc/init.d/nginx restart
  • 2
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
FastAPI是一个现代、快速(高性能)的Web框架,它使用最新的ASGI标准。Gunicorn是一个使用WSGI标准的应用服务器,它可以直接运行Flask和Django,但不能直接运行FastAPI。为了在部署FastAPI时使用Gunicorn,可以借助uvicorn工作器。可以使用以下命令来启动FastAPI应用程序: ``` gunicorn main:app --workers 2 --worker-class uvicorn.workers.UvicornWorker --bind 0.0.0.0:8000 ``` 这个命令中,`main`是你的应用程序的入口文件名,`app`是FastAPI应用程序的实例名。`--workers 2`表示使用2个工作进程,`--worker-class uvicorn.workers.UvicornWorker`表示使用uvicorn工作器,`--bind 0.0.0.0:8000`表示绑定到0.0.0.0的8000端口。这样就可以使用Gunicorn和uvicorn工作器来部署FastAPI应用程序了。123 #### 引用[.reference_title] - *1* *2* [ubuntu+nginx+gunicorn+uvicorn+fastapi](https://blog.csdn.net/qq_41960127/article/details/128832617)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] - *3* [Docker生产环境部署FastAPI+supervisor+gunicorn+nginx](https://blog.csdn.net/weixin_45457042/article/details/129213133)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值