百度网盘:https://pan.baidu.com/s/11wMIXT68GX7banf3Gaflrw (提取码:lzt1)
GitHub:https://github.com/Newbie-Rookie/Project-deployment
已经将项目部署需要用到的工具放到网盘中和GitHub上
在进行项目部署前,你先需要拥有一台服务器、XShell软件、XFtp软件
(1) 服务器
上阿里云、腾讯云租一台即可,可以看看官网的最新活动的限时秒杀(腾讯云),每天固定时间有优惠活动。
我目前用的是腾讯云的云服务器,学生有优惠https://cloud.tencent.com/act/campus(需要学生认证)
用购买服务器的账号登录服务器控制台(腾讯云控制台),找到购买的云服务器,进入实例
我们需要记住服务器初始登录名为root,密码我们进行重置密码,更改为我们容易记住的密码,用于登录XShell和XFtp
我们还要记住公网IP
(2) XShell和XFtp
XShell是命令操作服务器上资源的软件,XFtp是可视化操作服务器上资源的软件。
官网下载XShell 7和XFtp 7即可,但目前不知道为什么进不去官网,我把软件放网盘和github上,需要的自取。
① XShell连接云服务器:
点击该连接进行连接,需要再次输入登录名root和你所重置的密码即可连接成功。
② XFtp连接云服务器:
填写云服务器公网IP、登录名和密码,进行连接即可
以上将服务器、XShell和XFtp准备好后,我们就需要搭建项目运行环境,分四个步骤。
Oracle官网:https://www.oracle.com/java/technologies/downloads/#java8
需要Oracle账户(百度搜索Oracle账户,嫖一个下载就ok)
下载:jdk-8u321-linux-x64.tar.gz(已为你们准备了jdk-8u311-linux-x64.tar.gz在网盘和GitHub中)
XFtp进入/usr/local,将jdk-8u311-linux-x64.tar.gz进去
以下在XShell中进行:
进入/usr/local,即jdk源代码压缩包位置:
cd /usr/local
解压jdk源代码压缩包:
tar -zxvf jdk-8u311-linux-x64.tar.gz
删除jdk源代码压缩包:
rm -f jdk-8u311-linux-x64.tar.gz
解压成功:
/etc/profile文件的改变会涉及到系统的环境,也就是有关Linux环境变量的东西
所以,我们要将jdk配置到/etc/profile,才可以在任何一个目录访问jdk
vim /etc/profile
按i进入编辑,在profile文件尾部添加如下内容:
export JAVA_HOME=/usr/local/jdk1.8.0_311 #jdk安装目录
export JRE_HOME=${JAVA_HOME}/jre
export CLASSPATH=.:${JAVA_HOME}/lib:${JRE_HOME}/lib:$CLASSPATH
export JAVA_PATH=${JAVA_HOME}/bin:${JRE_HOME}/bin
export PATH=$PATH:${JAVA_PATH}
添加后如下:
然后按Esc退出编辑,按:wq退出配置文件即可
通过命令source /etc/profile让profile文件立即生效:
source /etc/profile
javac
java -version
我部署的项目中使用的是apache-tomcat-9.0.56,所以网盘和GitHub为你们准备了apache-tomcat-9.0.56.tar.gz
项目中使用的9及9以下版本都可以用,如果使用的是10以上版本,需要自己到官网下载,因为10以上版本的包名已经和9及9以下版本的包名不同,9及9以下版本
XFtp进入/usr/local,将apache-tomcat-9.0.56.tar.gz进去
解压:
tar -zxvf apache-tomcat-9.0.56.tar.gz
重命名:
mv apache-tomcat-9.0.56 tomcat
删除压缩包:
rm -f apache-tomcat-9.0.56.tar.gz
解压成功:
进入目录tomcat的bin目录:
cd /usr/local/tomcat/bin/
启动:
./startup.sh
查看tomcat启动效果:
在浏览器输入公网IP + 8080 (8080默认端口)
这就表示成功在Linux上安装了Tomcat。
我的项目使用的是MySQL8.0,所以我安装MySQL8.0
使用以下命令查找出安装的mysql软件包和依赖包:
rpm -qa | grep mysql
可能显示结果如下:
mysql80-community-release-el7-1.noarch
mysql-community-server-8.0.11-1.el7.x86_64
mysql-community-common-8.0.11-1.el7.x86_64
mysql-community-libs-8.0.11-1.el7.x86_64
mysql-community-client-8.0.11-1.el7.x86_64
使用以下命令依次删除上面的程序:
yum remove 名字
删除mysql的配置文件,卸载不会自动删除配置文件,首先使用如下命令查找出所用的配置文件:
find / -name mysql
可能显示结果如下:
/etc/selinux/targeted/active/modules/100/mysql
/usr/share/mysql
/usr/lib64/mysql
使用以下命令依次删除上面的程序:
rm -rf 名字
由于MySQL在CentOS 7中收费了,所以已经不支持MySQL了,取而代之在CentOS7内部集成了mariadb,而安装MySQL的话会和MariaDB的文件冲突,所以需要先卸载掉MariaDB.
使用rpm命令查找出要删除的mariadb文件:
rpm -qa | grep mariadb
可能的显示结果如下:
mariadb-libs-5.5.56-2.el7.x86_64
rpm -e mariadb-libs-5.5.56-2.el7.x86_64 #删除上面的程序
可能出现错误提示如下:
依赖检测失败:
libmysqlclient.so.18()(64bit) 被 (已安裝) postfix-2:2.10.1-6.el7.x86_64 需要
libmysqlclient.so.18(libmysqlclient_18)(64bit) 被 (已安裝) postfix-2:2.10.1-6.el7.x86_64 需要
libmysqlclient.so.18(libmysqlclient_18)(64bit) 被 (已安裝) postfix-2:2.10.1-6.el7.x86_64 需要
使用强制删除:
rpm -e --nodeps mariadb-libs-5.5.56-2.el7.x86_64
至此就将原来有的mysql 和mariadb数据库删除了。
目前我用的是腾讯云CentOS 7.6 64位,将安装MySQL8.0
由于从CentOS 7系统开始,MariaDB成为yum源中默认1的数据库安装包,如果我们的Linux操作系统为CentOS 7及以上版本,使用yum命令安装MySQL包时可能将无法启动MySQL,且自己从官网下载Linux系统的MySQL安装包到Linux系统中也一样,也会出现无法启动MySQL服务的问题,我尝试了许多方法,暂时没有找到解决方法。
直到我发现了一篇博文的方法比较靠谱,而且尝试可行:CentOS 7.6 安装MySQL8.0
即手动下载mysql的Yum Repository
到MySQL官网下载mysql的Yum Repository:MySQL Yum Repository
根据不同版本的CentOS系统进行下载,点击Download,我的是Linux 7
使用XShell,连接服务器,用wget下载mysql的rpm包:
wget https://repo.mysql.com//mysql80-community-release-el7-5.noarch.rpm
如上图,则下载成功。
yum -y install mysql-community-server
最后结果如上图,则安装成功。
启动mysql服务:
systemctl start mysqld.service
查看mysql状态:
systemctl status mysqld.service
active表示mysql服务已启动。
获取root用户初始密码:
grep "password" /var/log/mysqld.log
初始密码先记住,最好复制,第一次登陆时要用,如果忘记,可以百度一下怎么无密码登录(在这里我就不讲了)
因为安装了Yum Repostiory,以后每次yum操作都自动更新,需要把这个卸载掉:
yum -y remove mysql80-community-release-el7-5.noarch
关闭和重启mysql:
systemctl stop mysqld.service #关闭mysql
service mysqld restart #重启mysql
登录root用户并修改密码:
mysql -uroot -p
回车后将刚刚生成的初始密码复制进去,再回车即可
修改密码:
ALTER USER 'root'@'localhost' IDENTIFIED BY '新密码';
如果出现以下错误:是密码安全性未达到要求,你可以先设置比较复杂,你容易记的密码先,因为第一次登陆必须先修改密码才能进行其他操作
ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
登陆之后,可查看MySQL完整的初始密码规则:
SHOW VARIABLES LIKE 'validate_password%';
可以临时修改validate_password.length和validate_password.policy的值,再设置较为简单的密码:
set global validate_password_length=4;
set global validate_password_policy=0;
这样就可以通过上面的修改密码语句将密码修改为较为简单的密码。
use mysql; # 使用mysql数据库
select user,host from user; # 查看用户及用户登录权限
上面表示的的四个用户均只能本地登录,不允许远程登录,所以我们需要新增用户,并赋予远程连接权限
(1)新增远程连接用户:
# CREATE USER '用户名'@'主机' IDENTIFIED BY '密码';
CREATE USER 'lzt'@'%' IDENTIFIED BY 'lzt';
(2)设置远程连接权限
grant all privileges on *.* to 'lzt'@'%';
(3)刷新权限
flush privileges;
很多用户在使用Navicat Premium 12(我就是用这个版本,不用破解,即下即用)连接MySQL数据库时会出现Authentication plugin ‘caching_sha2_password’ cannot be loaded的错误。
出现这个原因是MySQL8.0之前的版本中加密规则是mysql_native_password,而MySQL8.0之后,加密规则是caching_sha2_password, 解决问题方法有两种,一种是升级Navicat驱动(太麻烦),一种是把mysql用户登录密码加密规则还原成mysql_native_password
# 修改加密规则
ALTER USER 'root'@'localhost' IDENTIFIED BY 'password' PASSWORD EXPIRE NEVER;
# 更新用户密码
ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '密码';
ALTER USER 'lzt'@'%' IDENTIFIED WITH mysql_native_password BY '密码';
上面我们已将项目部署所需要的东西都准备好,现在我们只需要将我们的项目进行打包,由于我的项目使用了Maven,我将项目打包成war文件,然后将文件使用XFtp软件放到Linux中/usr/local/tomcat/webapps中,即可通过 公网IP/端口(默认8080)/资源名 进行访问:
到此项目部署完成(不同类型的项目进行部署会有差别,此项目部署较适用于JavaWeb项目、Maven项目)