部署若依springboot-vue前后端分离项目(Nginx反向代理 2022)


前言

学习自codeSheep
原视频链接

使用若依前后端分离项目做部署例子
即ry-vue

既然是部署项目
你应该有一台远程服务器

使用宝塔面板
注意每次修改nginx.conf后记得重新加载配置并重启


1、本地启动项目

主要要把redis
mysql 和 log日志的路径设置正确
我购买了阿里云的服务器
直接连接服务器的mysql 和 redis

1.1 配置远程连接服务器redis

关于宝塔如何开启redis远程访问请看这篇文章
链接

在这里插入图片描述

# redis 配置
  redis:
    # 地址
    host: 139.224.237.xxx
    # 端口,默认为6379
    port: 6379
    # 数据库索引
    database: 0
    # 密码
    password: 1xxxx
    # 连接超时时间
    timeout: 10s
    lettuce:
      pool:
        # 连接池中的最小空闲连接
        min-idle: 0
        # 连接池中的最大空闲连接
        max-idle: 8
        # 连接池的最大数据库连接数
        max-active: 8
        # #连接池最大阻塞等待时间(使用负值表示没有限制)
        max-wait: -1ms

1.2 配置远程连接服务器mysql

做这一步的前提是你的服务器上已经有了ry-vue这个数据库
可以通过宝塔面板自带的phpadmin直接运行sql文件
导入数据库
在这里插入图片描述
在这里插入图片描述

关于宝塔如何开启mysql远程访问请看这篇文章
链接

在这里插入图片描述

            # 主库数据源
            master:
                url: jdbc:mysql://139.224.xxx.xxx:3306/ry-vue?useUnicode=true&characterEncoding=utf8&zeroDateTimeBehavior=convertToNull&useSSL=true&serverTimezone=GMT%2B8
                username: root
                password: 123456

1.3 配置log文件输出位置和字符集

1
我这里是在root目录下
自己mkdir log创建了一个
在这里插入图片描述
2
配置字符集
所有标签下都设置

<charset>UTF-8</charset>

避免日志乱码
在这里插入图片描述

最后本地启动项目
启动成功
在这里插入图片描述

2 打包

2.1 打包你的前端项目

1 在服务器打包前端项目

把前端项目压缩成zip后上传到服务器
解压后
cd到目录执行命令

npm install --unsafe-perm --registry=https://registry.npm.taobao.org

安装基本依赖

接着运行如下命令进行打包

npm run build:prod

如果出现报错

/node_modules/.bin/vue-cli-service: Permission denied

更改一下权限再run build
chmod 777 项目文件夹/node_modules/.bin/vue-cli-service

最后会在项目目录生成一个dist文件夹

2 在本地打包前端项目

操作一样
本地的dist文件夹记得传给服务器

2.2 打包你的后端项目

1 打成jar包
直接本地IDEA

packge

把生成的Jar包传给服务器即可

2 打成war包(可以把war包部署到服务器的tomcat中)
1 jar包改成war
在这里插入图片描述
2 新增一个依赖
在这里插入图片描述

        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-tomcat</artifactId>
            <scope>provided</scope>
        </dependency>

3 新增一个类
在这里插入图片描述

package com.ruoyi;

import org.springframework.boot.builder.SpringApplicationBuilder;
import org.springframework.boot.web.servlet.support.SpringBootServletInitializer;

public class SpringbootStartApplication extends SpringBootServletInitializer {
    @Override
    protected SpringApplicationBuilder configure(SpringApplicationBuilder builder) {
        return builder.sources(RuoYiApplication.class);
    }
}

接着clean

package打出war包
在这里插入图片描述

3 部署你打包的文件(前端部署和后端部署)

3.1 前端部署

首先找到你的nginx文件夹的位置
打开conf文件夹
找到nginx.conf
准备对其进行修改
在这里插入图片描述
新加一个server节点
对下面的配置文件进行解释
在这里插入图片描述

监听xxx主机的 8084端口

只要一访问该端口就会被定位到root 对应目录下的资源
这里的root目录对应的就是你前端打包的dist文件夹对应的绝对路径’
从index进入资源
try_files xxxx 解决的是刷新页面404的问题

可以使用pwd命令查看绝对路径
在这里插入图片描述

server
    {
        listen 8084;
        server_name localhost;
        index index.html index.htm index.php;
        root  /www/server/nginx/html/ry_before;
        try_files $uri $uri/ /index.html;	


	

        location /prod-api/
        {
             #proxy_redirect off;
             proxy_set_header Host $http_host;
             proxy_set_header REMOTE-HOST $remote_addr;
             proxy_set_header X-Real-IP $remote_addr;
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
             proxy_pass http://139.224.237.247:8087/;
        }


        #error_page   404   /404.html;
        include enable-php.conf;

        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
        {
            expires      30d;
        }

        location ~ .*\.(js|css)?$
        {
            expires      12h;
        }

        location ~ /\.
        {
            deny all;
        }
        
        


        access_log  /www/wwwlogs/access.log;
    }

接着重载配置
重启你的nginx服务器 访问对应服务器ip加上端口号
如果是阿里云等服务器 配宝塔 记得放行阿里云和宝塔端口
在这里插入图片描述

3.2 后端部署

前端部署好以后F12
发现请求都是404
在这里插入图片描述
首先启动你的后台
cd到后端项目目录下

# 在后台一直运行这个jar包
# 这个jar包的端口我改为了 8087 因为我本地博客的端口在8080 冲突了

nohup java -jar ruoyi-admin.jar &

如果想要杀死这个后台

ps -aux | grep java

kill -9 pid

配置nginx
把8084/prod-api/capxxxx

的请求转为

8087/capxxxx

        location /prod-api/
        {
             #proxy_redirect off;
             proxy_set_header Host $http_host;
             proxy_set_header REMOTE-HOST $remote_addr;
             proxy_set_header X-Real-IP $remote_addr;
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
             proxy_pass http://139.224.237.247:8087/;
        }

完整配置

server
    {
        listen 8084;
        server_name localhost;
        index index.html index.htm index.php;
        root  /www/server/nginx/html/ry_before;
        try_files $uri $uri/ /index.html;	


	

        location /prod-api/
        {
             #proxy_redirect off;
             proxy_set_header Host $http_host;
             proxy_set_header REMOTE-HOST $remote_addr;
             proxy_set_header X-Real-IP $remote_addr;
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
             proxy_pass http://139.224.237.247:8087/;
        }


        #error_page   404   /404.html;
        include enable-php.conf;

        location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
        {
            expires      30d;
        }

        location ~ .*\.(js|css)?$
        {
            expires      12h;
        }

        location ~ /\.
        {
            deny all;
        }
        
        


        access_log  /www/wwwlogs/access.log;
    }

再访问前端就一切正常了

4 nginx后台集群部署

修改你的nginx.conf
与server同级新增配置
在这里插入图片描述

upstream ruoyi{
	server 192.你的服务器1地址.xxx:端口 weight=权重;
	server 192.你的服务器2地址.xxx:端口 weight=权重;
}

在这里插入图片描述

        location /prod-api/
        {
             #proxy_redirect off;
             proxy_set_header Host $http_host;
             proxy_set_header REMOTE-HOST $remote_addr;
             proxy_set_header X-Real-IP $remote_addr;
             proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
             proxy_pass http://ruoyi/;
        }

这样配置好了集群
后端有一个服务器挂掉也不影响正常运行

5 观看日志

cd 到你配置文件部署的路径下
观看日志
在这里插入图片描述

在这里插入图片描述

### SpringBootVue 前后端分离项目部署至阿里云服务器教程 #### 服务器准备 为了成功部署SpringBootVue组成的前后端分离项目,需先准备好阿里云ECS服务器。对于初次使用者来说,建议选择配置适合开发测试环境的基础型实例即可满足需求[^1]。 #### 工具安装与环境搭建 确保已安装必要的工具如Xshell用于SSH远程登录管理服务器以及Xftp实现文件传输功能。此外,在服务器内部还需完成Java运行环境(JDK)、Node.js等相关依赖项的设置以便支持应用正常运作[^2]。 #### 后端服务发布流程 针对基于Spring Boot框架构建的应用程序而言,可以考虑采用打包成jar包的形式上传至目标主机并执行启动命令的方式来进行部署;或者利用Docker容器化技术简化运维过程中的复杂度,提高跨平台兼容性和稳定性。 ```bash nohup java -jar your-springboot-app.jar & ``` 如果选择了后者,则应提前规划好镜像制作、推送至仓库等环节的工作内容,并编写相应的docker-compose.yml来定义多容器编排方案。 #### 前端资源上线方法 对于由Vue CLI创建出来的单页面应用程序(SPA),通常会将其构建成静态网页形式并通过Nginx反向代理映射到指定域名下访问。因此需要在本地环境中通过`npm run build`指令生成dist目录下的生产版本文件夹之后再借助FTP/SFTP等方式同步至线上空间内[^3]。 ```nginx server { listen 80; server_name example.com; location / { root /path/to/dist; try_files $uri $uri/ /index.html; } } ``` 最后重启Nginx使更改生效: ```bash sudo systemctl restart nginx ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qwecxzz

鸡腿

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值