文章目录

  • 前言
  • 一、环境准备
  • 二、项目打包
  • 1.项目准备
  • 2.后端打包
  • 3.前端打包
  • 三、项目部署
  • 1.后端项目部署
  • 2.前端项目部署
  • 四、遇到的问题



前言

本文参考视频实践若依的前后端分离项目的部署运行,记录整理一下自己的整个部署运行过程和遇到的问题,小白入门~
视频在此:
https://www.bilibili.com/video/BV1uK411p7Bp?spm_id_from=333.337.search-card.all.click


一、环境准备

在本文中前后端项目都部署在一台云服务器上
1、首先服务器需要安装好相关的软件:jdk、mysql、nginx、tomcat、redis
服务器相关软件的安装参考:
https://www.bilibili.com/video/BV1oK4y147Qu?spm_id_from=333.337.search-card.all.click

2、由于是本地idea打包后上传到服务器,所以本地需要安装node便于后续的前端打包

win下安装Node参考:(或者自行查询只要能安装成功都行)

二、项目打包

1.项目准备

1、项目拉取
项目地址:https://gitee.com/y_project/RuoYi-Vue

2、在idea中打开项目,需要修改数据库连接等配置项

(1) 修改/src/main/resources/application-druid.yml

修改数据库连接信息:

java若依是什么 若依项目视频_ide


(2) 修改/src/main/resources/application.yml

修改后端运行端口:(默认8080)

java若依是什么 若依项目视频_ide_02

修改redis连接信息:

java若依是什么 若依项目视频_nginx_03


(3) 修改src/main/resources/logback.xml

注意:该文件下所有的encoder都要添加上字符集的配置

java若依是什么 若依项目视频_ide_04


(4) 连接数据库客户端,进行数据库表的创建

将Ruoyi-Vue下的sql目录下面的俩sql文件导入客户端进行库表的创建

java若依是什么 若依项目视频_nginx_05

2.后端打包

使用maven打jar包

java若依是什么 若依项目视频_ide_06


打包成功后会在ruoyi-admin/下生成一个target目录

java若依是什么 若依项目视频_服务器_07


target目录下会有打好的jar包

java若依是什么 若依项目视频_ide_08

本地运行mian程序后,打开http://localhost:8081/captchaImage有返回则后端打包成功

3.前端打包

前提本地准备好了node环境,idea中有vue.js的插件

进入idea的命令行,打开ruoyi-ui目录:输入npm install

java若依是什么 若依项目视频_经验分享_09


打一下开发环境的包

java若依是什么 若依项目视频_服务器_10


完成后浏览器打开idea提供的网址:http:localhost:80页面能打开则前端打包成功,暂时不需要管后端接口的报错接下来打正式环境的包

(执行命令行的时候注意是在ruoyi-ui目录下)

java若依是什么 若依项目视频_java若依是什么_11


(也可以找到ruoyi-ui下的package.json文件,右击文件就会出现npm的可运行脚本)

java若依是什么 若依项目视频_java若依是什么_12


打包成功后会在ruoyi-ui目录下生成dist目录

java若依是什么 若依项目视频_java若依是什么_13

三、项目部署

1.后端项目部署

(1) 将打好的jar包上传到服务器上,我直接上传到了root目录下

java若依是什么 若依项目视频_服务器_14


(2) 启动java :nohup java -jar ruoyi-admin.jar &

通过查看nohup.out文件是否启动成功

[root@ls ~]# nohup java -jar ruoyi-admin.jar  &
[root@ls ~]# tail -100f nohup.out

通过访问ip:端口(端口是启动后端的端口)看是否在服务器上部署运行成功

java若依是什么 若依项目视频_java若依是什么_15

2.前端项目部署

(1) 在本地将dist目录压缩后上传到服务器,在服务器上解压,解压的目录需要知道,后续需要用到。

java若依是什么 若依项目视频_nginx_16


(2) 修改nginx配置,利用nginx将前端代码运行起来,同时解决跨域问题

[root@ls ~]# cd /usr/local/nginx/conf
[root@ls conf]# vim nginx.conf

java若依是什么 若依项目视频_服务器_17


java若依是什么 若依项目视频_ide_18

location /prod-api/ {
           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://服务器ip:后端启动端口号/;

}

修改完成后:wq,保存退出
(3) 启动nginx

[root@ls ~]# cd /usr/local/nginx/sbin
[root@ls sbin]# ll
total 3764
-rwxr-xr-x 1 root root 3851664 Apr 26 23:27 nginx
[root@ls sbin]# ./nginx

至此前后端项目都部署完成,访问服务器ip就好了~

四、遇到的问题

1、项目部署成功后,首次进入管理页面正常,但是一刷新就报404
解决途径:修改nginx.conf文件,在根目录下添加
try_files $uri $uri/ /index.html

location / {
            root   /usr/local/workspace/RuoYi-Vue/ruoyi-ui/dist/;
            try_files $uri $uri/ /index.html
            index  index.html index.htm;
        }

2、java启动的时候报数据库连接不上或者时redis连不上,这可能是防火墙的端口号没有开放
解决途径:增加防火墙开放的端口
安装firewalld服务

[root@ls ~]# apt-get install firewalld
[root@ls ~]# yum install firewalld

增加数据库、redis以及需要对外开放的端口,编辑如下文件
复制-A INPUT -p tcp -m state --state NEW -m tcp --dport 21 -j ACCEPT
将端口号21改为自己需要的端口号(也可以通过其他方式开放防火墙端口)

[root@ls ~]# vim /etc/sysconfig/iptables

java若依是什么 若依项目视频_ide_19


3、防火墙被锁定的问题

java若依是什么 若依项目视频_ide_20


执行如下命令即可

[root@ls ~]# systemcyl unmask firewalld

4、在安装mysql的时候莫名其妙密码不正确了,连接都连接不上
关于Linux的mysql重置密码可以参考: