在前后端分离的情况下,如何单独将Springboot项目部署到服务器?以下是我的在第一次部署之后的记录和总结,希望可以帮到同样也刚刚用到服务器的你。
部署服务器主要的几个步骤:
- 服务器环境配置;
- 配置项目并打包;
- 部署到服务器;
- 后台运行项目。
服务器环境配置
服务器环境:Debian8 x64(vps)
本机环境:Mac,Intellij IDEA,FinalShell
我们需要一个SSH工具来连接到服务器,因为我使用的Mac,所以使用了FinalShell(算是好用吧)。如果安装了brew,你就可以通过brew cask install finalshell
来安装FinalShell。Win用户可以使用Putty等软件。
此处假设你已会简单使用SSH,并已经连上了你的服务器。
Linux安装并配置JDK
准备
以root身份登录,因为我的vps默认就是root,所以我不用登录,如果需要的话,你可以输入su
回车,然后再输入你的密码(linux输入密码不显示星号或其他替换符号),再回车即可。
确认你的系统是否自带jdk,可以通过输入:
apt-get list installed | grep java
来列举匹配已安装的java。如果没有,则继续;如果有,可以试试:
apt-get -y remove java-1.7.0-openjdk*
来卸载(因为我没有试过)。
接下来,我们新建一个目录来存放jdk。
mkdir /home/java
进入该目录。
cd /home/java
接下来的操作都是基于此路径进行,如果是存放在其他路径下,请注意对应修改。
下载压缩包
先到官网上查看需要的jdk版本,获取压缩包的下载链接,再使用命令下载
这里选用jdk8,在本地点击打开下载主页,选中Accept License Agreement,点击Linux版本的的.tar.gz
文件(x64或x86视你的Linux而定,可通过uname -a
命令查看,有64即可下x64版本),复制对应的下载链接,这里不需要下载,只是为了获取下载链接。
输入命令:
curl -O https://download.oracle.com/otn-pub/java/jdk/8u201-b09/42970487e3af4f5aa5bca3f542482c60/jdk-8u201-linux-x64.tar.gz?AuthParam=1554125860_f7bf6ea27a443245f5d1cb9fde89b37d
注意O
是大写的字母。
-O 后面跟着刚才复制的下载链接,这个貌似要实时获取的链接才能下载,有AuthParam参数来校验,否则你会看到所有项都是 0 ,不会变化;出现这个情况的话,重新去点击那个文件,获取下载链接复制过来再试。
用ls
命令查看,可以看到当前目录下出现了一个jdk-8xxx.tar.gz
文件(后缀的AuthParam=...不用管)。
解压并安装
使用命令解压(输入文件名可以输入前一部分,然后按tab键自动补全)
tar -zxvf jdk-8u201-linux-x64.tar.gz...
此时使用ls
命令可以看到路径下多处了一个目录jdk1.8.0_201
。
检查下载下来的jdk是否正常,输入以下命令验证:
/home/java/jdk1.8.0_201/bin/java -version
/home/java/jdk1.8.0_201/bin/javac -version
如果能够正常显示jdk的版本信息,即为正常;否则,重新下载。
设置环境变量
打开/ect/profile
文件,并在文件末尾添加(JAVA_HOME的值根据实际路径填写):
# set java environment
# 注意‘jdk1.8.0_201’需要根据你的实际文件夹名做出更改
export JAVA_HOME=/home/java/jdk1.8.0_201
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib
export PATH=${JAVA_HOME}/bin:$PATH
你可以通过以下两种方式使配置生效:
- 重启机器:
reboot
; - 使用source命令:
source /etc/profile
、source ~/.bashrc
分别输入命令 java -version
和javac -version
,若显示jdk的版本信息,说明已正确配置。
可能出现的问题
- 如果出现了
-bash: java: command not found
,检查上面的各个步骤,然后出现这个情况的,请仔细检查配置文件!以及/etc/profile
的各项值是否设置正确。 - 如果出现了
-bash: ./java: cannot execute binary file
,出现这个错误的原因可能是在32位的操作系统上安装了64位的jdk,检查jdk版本和Linux版本位数是否一致。
安装Mysql|MariaDB
MariaDB 和 MySQL是一家。MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可 MariaDB的目的是完全兼容MySQL,包括API和命令行,使之能轻松成为MySQL的代替品。
这里 安装 MariaDB 来用用,使用ssh工具连接登录上Linux。
安装MariaDB
apt-get -y install mariadb-server
安装时会让你设置数据库root用户的密码,这个密码和LInux的root用户密码是不同的。
注:在我后来又一次安装MariaDB时,直接跳过了设置密码的过程,这时密码是空的,所以之后输入密码的时候直接回车即可。关于MariaDB初始的一些配置,我在博客(点击上面的原文)里更新了,简书上懒得做更细致的更改。
Debain上MariaDB好像是自动启动的。
配置和简单使用
通过命令:
mysql -u root -p
进入,然后输入你设置的密码。
修改数据库字符集,使支持中文。先要查看数据库的原字符集设定可登录mysql后,
MariaDB [(none)]> show variables like 'char%';
可以看到:
MariaDB [(none)]> show variables like 'char%';
+--------------------------+----------------------------+
| Variable_name | Value |
+--------------------------+----------------------------+
| character_set_client | utf8 |
| character_set_connection | utf8 |
| character_set_database | utf8 |
| character_set_filesystem | binary |
| character_set_results | utf8 |
| character_set_server | utf8 |
| character_set_system | utf8 |
| character_sets_dir | /usr/share/mysql/charsets/ |
+--------------------------+----------------------------+
8 rows in set (0.00 sec)
默认character_set_database项不为utf8,可以通过修改/etc/mysql/my.cnf
配置文件更改。在该文件的mysqld
字段内加上一句character-set-server=utf8
。
因为我使用systemctl restart mariadb
重启mariadb服务无效,所以只能通过reboot来使配置生效。
将本地Springboot项目打包
确保你的项目完整,然后在右侧(或者边栏的其他地方)的Maven Projects中选中package双击或者右键点击Run Maven Build,然后你会看到在运行框程序正在打包。打包默认是你最初建项目时选中的jar工程。
当运行框出现BUILD SUCCESS说明你的项目已经打包成功了,打包好的jar包是在项目的target文件夹下。
将本地数据库上传至服务器
我本地使用的是Mysql+Navicat Premium,如果你也是用的这个组合,那么接下来的操作会很简单。如果你没安装Navicat Premium,可以看Navicat Premium for Mac破解教程。如果是其他情况,我的文章里没有记录,请自行百度。下面是具体步骤:
打开Navicat Premium,连接到你的服务器的数据库(请注意打开服务器的3306端口);
在服务器MySQL创建一个和 要迁移数据的数据库 同名的数据库,为了方便,直接在Navicat图形界面操作(有兴趣可以在命令行操作),右键 服务器连接 -> 创建数据库 -> 输入要迁移的数据库名,字符集选择utf8 – UTF-8 Unicode -> 确定;
进行数据迁移,点击Navicat菜单栏“工具” -> 数据传输… -> 设置“源”为本地数据库“localhost”,设置“目标”为服务器数据库,选择要传输的数据库,和接收数据的数据库 -> 开始传输 -> 确定 -> 传输中… -> 关闭(这是已经传好了,别点“开始”,不然又传一次)。
部署到服务器并运行
部署Springboot项目的话就不用下载tomcat了,Springboot内嵌tomcat。如果是之后还要部署其他项目,也可提前把tomcat下了。如果你配置了安全组或者防火墙,请打开必要的端口(即项目的端口)
将生成的jar文件上传至你的服务器(可以任意位置),比如我上传至了/home
下。
cd到jar文件路径下,然后使用命令:
nohup java -jar demo-0.0.1-SNAPSHOT.jar >/home/test.log>&1&
nohupjava -jar 项目名称.jar >/路径名称/输出的日志名称.log>&1&
然后可以直接在对应的端口/接口访问,也可以使用命令进行查看项目是否已经后台运行。可以使用:
ps -ef
查看进程运行的情况。
root 16974 5043 0 08:55 ? 00:00:00 bash -c export LANG="en_US.UTF-8";export LANGU
root 16979 16974 0 08:55 ? 00:00:00 sleep 1
root 16980 5049 0 08:55 pts/0 00:00:00 ps -ef
root 23904 1 0 04:23 ? 00:00:38 java -jar login-demo-0.0.1-SNAPSHOT.jar
可以看到项目的进程号23904正在运行。
如果需要停止项目的运行直接使用命令:kill 23904
(进程号)
测试运行
推荐使用Postman进行端口的测试。