Django_Vue3_ElementUI_Release_004_使用nginx部署

1. nginx安装配置

1.1 下载nginx

Download nginx

1.2 测试一下

1.3 进入nginx用命令操作

2. 部署

2.1 前端部署

2.1.1 修改nginx监听配置

...conf/nginx.conf

bash 复制代码
http {
  ... # 这里不进行修改
  server {
    listen 8010; # 监听 80 端口
    server_name 192.168.10.24; # 输入服务器 ip,我这里为内网 ip
    
    location / {
      root html;
      index index.html index.htm; # 这里默认为此配置,表示当有人访问 服务器 80 端口的 / 根目录,那么 Nginx 将在 html 文件夹中寻找 index.html, index.htm 文件进行展示,也可以根据自己实际情况进行修改
      # 如果 vue 的路由模式是 history,一定要加上下面这句话
      try_files $uri $uri/ /index.html;
    }
  }
}

2.1.2 修改vue axios监听配置

和nginx的保持一致,因为之前是vue直接访问后端的,现在改成了nginx转发

2.1.3 修改完成后打包

npm run build

2.1.4 将dist文件夹中的内容拷贝到nginx的html目录中

2.1.5 浏览器访问测试

以上前端配置好了,但是不能访问后端

2.2 后端部署

2.2.1 nginx需要如下配置

c 复制代码
		location /api/ {
			add_header Access-Control-Allow-Origin *;
			proxy_set_header Host $http_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;
			# Nginx 监听到请求 api后,将请求转发给 localhost的8000端口,
			# 因为 Django后端也要部署到这台服务器上,所以是 localhost,
			# 这样可以减少用户请求次数,加快网站访问速度。(我实测速度是有一定提升)
			proxy_pass http://127.0.0.1:8000;  
		  }

以上配置文件中的ip地址和端口需要和django中保持一致

2.2.2 如果有静态文件,需要如下配置

c 复制代码
		location /static/ {  
			# 这里为你的需要访问文件的访问路径,
			# 我的文件访问路径是 http://192.168.50.10/static/papers/XXX.pdf,
			# 我的文件存储在了 static/papers/XXX.pdf,并且一同复制到了 html 文件夹中。
			alias D:/Web/nginx-1.24.0/html/static/;  
			# 这里为服务器中 html 内,你的文件的存储路径。
			try_files $uri $uri/;
		  }

2.2.3 settings.py中做如下配置

3. 测试

启动nginx并访问

4. 修复django admin

在 服务器的 Django 的 settings.py 中,新增以下配置

c 复制代码
STATIC_ROOT = "D:/Web/nginx-1.24.0/html/static/static/" # 这里为你的服务器中 Nginx 的路径,应在 html 文件夹下的 static 文件夹,但是我的static 文件夹存了论文不为空,因此我在 static 文件夹中新建了文件夹 static

随后在终端中执行

c 复制代码
python manage.py collectstatic  # 将 admin 样式复制到指定目录

将 html/static/static 文件夹的 admin 文件夹复制到 html/static 文件夹中。

随后在 Nginx 的 conf/nginx.conf 文件中进行如下配置。

c 复制代码
location /api/ {
  ... # 以上配置内容
}
location /admin/ {
  add_header Access-Control-Allow-Origin *;
  proxy_set_header Host $http_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;
  proxy_pass http://localhost:8000;
}
location /static/admin/ {
  alias D:/Web/nginx-1.24.0/html/static/admin/;  # 这里为 admin文件夹所在位置
  try_files $uri $uri/;
}
location /static/ {
  ... # 以上配置内容
}

以上内容参考

https://www.cnblogs.com/kyguo1997/p/17884479.html

相关推荐
tryCbest21 小时前
Nginx常用操作命令-Linux和Windows系统
linux·windows·nginx
龙腾AI白云21 小时前
多模大模型应用实战:智能问答系统开发
python·机器学习·数据分析·django·tornado
程序媛徐师姐1 天前
Python基于OpenCV的马赛克画的设计与实现【附源码、文档说明】
python·opencv·django·马赛克绘画·python马赛克绘画系统·马赛克画·python马赛克画
千码君20161 天前
kotlin:jetpack compose 生成动态可控的动画
vue.js·elementui·kotlin
斯班奇的好朋友阿法法1 天前
Django 项目打包部署完整指南(适配你的项目,零报错)
python·django·sqlite
難釋懷1 天前
Nginx实现本地缓存查询
nginx·spring·缓存
斯班奇的好朋友阿法法1 天前
Django 3.2 项目:从 Hello World 开始(完整功能版)
python·django
牧杉-惊蛰1 天前
修改表格选中时的背景色与鼠标滑过时的背景色
前端·javascript·css·vue.js·elementui·html
ZzzZZzzzZZZzzzz…1 天前
Nginx 平滑升级:从 1.26.3 到 1.28.0,用户无感知
linux·运维·nginx·平滑升级·nginx1.26.3·nginx1.28.0
robch2 天前
python3 -m http.server 8001直接启动web服务类似 nginx
前端·nginx·http