使用 Nginx 反向代理实现前后端分离部署

使用 Nginx 反向代理实现前后端分离部署

这里使用我的大二课程作业给大家在Windows下演示使用 Nginx 反向代理实现前后端分离部署

配置前端构建输出

打开你的 Vue 项目,在终端中输入npm run build命令,直到看见Build complete.说明打包完成

在这里插入图片描述

打包完成后你会在目录中看见一个dist文件夹,里面会有index.html文件和cssimgjs等文件夹

在这里插入图片描述

dist整个文件夹复制到 Nginx 根目录下的html文件夹中,同时可以修改文件夹为你需要的名字,我这里就叫maiba好了

在这里插入图片描述

设置 Nginx 反向代理

打开conf目录下的nginx.conf文件夹,修改配置,注意修改为自己对应的文件夹名后端服务地址

worker_processes  1;  # 定义工作进程数量

events {
    worker_connections  1024;  # 定义每个工作进程的最大连接数
}

http {
    include       mime.types;  # 包含文件类型定义
    default_type  application/octet-stream;  # 默认文件类型
    sendfile        on;  # 开启高效文件传输模式

    keepalive_timeout  65;  # 连接保持超时时间
    server {
        listen       80;  # 监听端口号
        server_name  localhost;  # 服务器名称

        location / {
            root   html/maiba;  # 网站根目录
            index  index.html index.htm;  # 默认首页文件
        }
        error_page   500 502 503 504  /50x.html;  # 错误页面配置
        location = /50x.html {
            root   html;  # 错误页面根目录
        }

        location /api/ {
            proxy_pass http://localhost:8081;  # 后端服务地址
            proxy_set_header Host $host;  # 设置请求头Host
            proxy_set_header X-Real-IP $remote_addr;  # 设置请求头X-Real-IP
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;  # 设置请求头X-Forwarded-For
            proxy_set_header X-Forwarded-Proto $scheme;  # 设置请求头X-Forwarded-Proto
        }
    }
}

在server中listen 80,表示服务器监听 HTTP 的 80端口,这是默认的 HTTP 端口。
在 location / 中,定义了网站的根目录 html/maiba 和默认首页文件 index.html,这是静态资源的主要入口。
而 location /api/ 通过 proxy_pass 把 API 请求转发到后端服务http://localhost:8081,实现前后端的通信。

部署与测试

项目的启动可以直接使用 IDE 启动,也可以打包成 Jar 包后命令启动,这里直接使用一键启动

访问自己电脑的 IP 地址或者使用localhost都可,由于 Nginx 中配置的是80端口(HTTP默认端口),所以直接访问 IP 地址或者localhost即可,无需特意输入端口,能看到前端页面和请求状态码200说明成功

在这种方式下,你需要同时运行 Nginx 和后端项目

在这里插入图片描述

博客原文链接直达:部署之道:整合、分离与容器化的前后端部署方法
想了解更多内容,请访问我的个人博客:Panda
欢迎志同道合的朋友一起学习交流,共同进步!

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值