Linux环境下Java项目基础环境搭建过程
作者:米糕闯编程
一、下载解压JDK和Tomcat(JDK为必备环境)
Linux软件安装方法:
1、tar:解压安装
- 安装包格式:tar、tar.gz、tar.bz
- 安装软件包命令:tar -zxvf [包名]
2、rpm:直接安装
- 安装包格式:rpm
- 安装软件包命令:rpm -ivh 软件包路径
- 卸载软件包命令:rpm -e 软件包全名
3、yum:在线安装
- 安装软件包命令:yum -y install subversion
- 卸载软件包命令:yum -y remove subversion
一般建议解压安装;JDK、Tomcat、MYSQL、maven的版本一般都建议与开发环境保持一致,并且要注意对应的Tomcat版本所支持的JDK版本,官网上几乎都能看到版本对应信息;
JDK安装:先去官网找到对应的版本,我这边做测试用的项目是比较老的,所以用的JDK8
可以在官网上找到自己的版本:

我的CentOS是X64,所以对应我要下载X64tar.gz,下载后自己保存到本地的一个目录;

Tomcat安装:在官网上查看对应JDK匹配的Tomcat版本
Apache Tomcat® - Which Version Do I Want?

我的项目是JDK8,这里只能用Tomcat9;
MYSQL安装:老项目,所以只能用MYSQL5,自己可以找找;
具体安装(我这边用的是安装包的解压,纯绿色版本,安装,卸载都比较方便)
1、JDK:使用xftp工具将本地对应的tar包上传到自己的CentOS里,这里我选的目录是opt,自己可以根据情况来选择自己的目录;

上传后可以通过命令ls 查看对应的文件,下面来一个个解压:

使用命令解压JDK:tar -zxvf jdk-8u481-linux-x64.tar.gz执行后开始解压:

解压后,会对应有个安装文件;

接着要去修改环境变量(注意,不要多加空格,特别是=号两边):
exprot JAVA_HOME=/opt/jdk1.8.0_481 exprot PATH=$JAVA_HOME/bin:$PATH
注意:$PATH一定要加上,这个是Linux系统里的环境变量,如果没有加上,可能会导致系统崩溃,很多命令都将用不了,所以一定要把原来的$PATH加上;

然后使用命令source /etc/profile 让刚刚修改的配置文件生效;
再使用java -version 查看刚刚安装的JDK版本;

至此JDK就安装、配置好了,然后再去安装Tomcat,一定要记得先装JDK,再去安装Tomcat,像有JDK依赖的工具都需要先安装好JDK,否则启动会报错,无法启动。
2、Tomcat:同理先解压tar包。
解压后,进入到对应的bin目录下,可以看到对应启动命令,注意.bat为Windows环境下的命令,.sh为Linux环境下的命令;

在bin目录下使用 sh startup.sh启动Tomcat;

启动后可以看到,Tomcat用的JDK是刚刚配置的1.8的;
我们再去进程里看看:使用命令
ps -ef | grep tomcat
可以看到Tomcat进程正在运行,我们用宿主机(我的是Windows)来访问看看:



很明显无法访问。
这里是因为Linux的防火墙机制,除了默认的22端口对外暴露,其他的要配置,可以使用命令查看下已开放的防火墙:
firewall-cmd --zone=public --list-ports

可以看到没有东西,所以我们的8080端口的Tomcat无法被其他地方访问到,现在我们开放我们的8080端口:(--permanent可以加,也可以不加,加了就是8080端口永久访问生效,不加就是当前访问有效,重新启动后需要重新配置端口的开放)
firewall-cmd --zone=public --add-port=8080/tcp --permanent
以上命令将8080端口开放;
开放后一定要记得重新加载防火墙,使刚刚的设置生效;
加载命令:
firewall-cmd --reload
在访问下开放的端口列表:
firewall-cmd --zone=public --list-ports
可以看到8080被开放了;

再去访问下:Windows上的页面和CMD都可以访问了。


注意如果同时启动两个Tomcat就要修改其中一个Tomcat的配置文件了,修改端口可以看Tomcat的使用指南;然后想让宿主机访问,记得添加访问端口到防火墙(步骤如上);
这个时候界面上的managerAPP是还不能用的,要界面能使用,管理我们的web项目,需要修改对应的,找到配置文件
tomcat-users.xml
编辑内容:将以下内容添加到tomcat-users.xml中,记得ESC后:wq!保存后退出,要记得自己的password和username,
manager-gui角色专门用于通过浏览器访问图形界面(/manager/html)。
<!-- 以下三行为开启界面用户使用managerAPP -->
<role rolename="admin-gui"/>
<role rolename="manager-gui"/>
<user username="admin" password="admin123" roles="manager-gui"/>这一步只是创建了可以访问该界面的用户,而Manager App的配置文件默认是只允许服务器本机访问的,所以还要配置context.xml,目录在webapps/manager/META-INF/下
将原来的:
<Valve className="org.apache.catalina.valves.RemoteCIDRValve"
allow="127.0.0.0/8,::1/128" />注释:
<!-- <Valve className="org.apache.catalina.valves.RemoteCIDRValve"
allow="127.0.0.0/8,::1/128" /> -->然后再去bin目录下重新启动tomcat,再去页面访问,进入:

可以界面管理项目了。

Tomcat的安装,启动相关就处理完了。
注:给tomcat配置不同的JDK,可以在单独的tomcat配置文件中修改;
#在bin/catalina.sh文件开头加上(JRE可以不配,JDK17没有JRE可用jlink命令做软链接) #Tomcat10以前也可以配置在setclasspath.sh文件中,从Tomcat10.1开始必须JDK11+ export JAVA_HOME=/opt/jdk17
3、MYSQL安装:同样先解压,解压后可以删除安装包;
1)解压后重命名(前面是原来的名字,后面是新的命名),方便后续使用:
命令:mv mysql-5.6.37-linux-glibc2.12-x86_64 mysql5.6
因为一般数据库由DB管理,一般会建一个专门的用户管理数据库;
添加用户组:
- 命令:groupadd mysqlzu
- 添加用户gaolu到用户组mysqlzu :
- 命令:useradd gaolu-g mysqlzu
创建数据文件夹(本地mysql相关数据信息都会在这个文件夹里,以后卸载对应版本,只要保存好这个文件,数据就可以继续使用,一般业务数据存放的地方):
命令:
cd /opt/mysql5.6/data mkdir my_mysql
将指定文件的拥有者改为指定的用户和组 :
命令:
chown -R gaolu:mysqlzu /opt/mysql5.6
2) 初始化数据库:user后面接你自己刚刚创建的Linux用户
命令:
/opt/mysql5.6/scripts/mysql_install_db --user=gaolu --basedir=/opt/mysql5.6/ --datadir=/opt/mysql5.6/data/mysql
含义:
| /opt/mysql5.6/scripts/mysql_install_db | 初始化脚本的路径。这是 MySQL 5.6 提供的专门用于初始化数据库的 Perl 脚本。在 MySQL 5.7.6 及更高版本中,这个脚本已被mysqld --initialize命令取代。 |
| --user=gaolu | 指定运行进程的操作系统用户。这告诉初始化脚本以mysql这个系统用户的身份来创建和运行数据库进程,是提升安全性的最佳实践。 |
| --basedir=/opt/mysql5.6/ | 指定 MySQL 的安装根目录。脚本会在这个目录下寻找 MySQL 的二进制文件(如bin目录)和共享文件(如share目录)。 |
| --datadir=/opt/mysql5.6/data/my_mysql | 指定数据库数据的实际存储目录。所有用户数据、系统表、日志文件等都将存放在这个路径下。 |
执行报错:

我忘记装Perl 解释器了,mysql_install_db是一个Perl 脚本。
使用命令
命令:yum install -y perl 在线安装;
安装后可以查到对应版本,再执行上述命令就可以正常初始化数据库了。

看到OK就初始化成功了!

3)初始化数据库成功后,要记得复制配置文件将mysql目录下的my-default.cnf复制到/etc/my.cnf:my-default.cnf为mysql的配置文件,mysql不会自动读取my-default.cnf
# MySQL 启动时的配置文件查找路径(优先级从高到低) /etc/my.cnf # 系统级配置(第1优先) /etc/mysql/my.cnf # 系统级配置(第2优先) /usr/local/mysql/etc/my.cnf # 安装目录配置 ~/.my.cnf # 用户级配置
命令:
cp support-files/my-default.cnf /etc/my.cnf
不配置的话:
# 删除/不创建 /etc/my.cnf rm -f /etc/my.cnf # 启动 MySQL /opt/mysql5.6/bin/mysqld_safe --user=gaolu & # MySQL 会使用编译时的默认值启动 # 可能的问题: # - 数据目录可能在默认位置 /var/lib/mysql(而不是 /opt/mysql5.6/data) # - 端口可能是 3306(但可能被占用) # - 字符集可能是 latin1(而不是 UTF-8) # - 没有错误日志文件
4)复制完了要记得修改 /etc/my.cnf配置,包括字符集之类:
命令:
vi /etc/my.cnf
在mysqld下添加:
port=3306
default-storage-engine=INNODB
character-set-server=utf8
lower_case_table_names=1
#修改过期时间
wait_timeout=31536000
interactive_timeout=31536000保存后退出(esc :wq!,按顺序按键);
5)接着修改:support-files/mysql.server
命令:
vi /opt/mysql5.6/support-files/mysql.server
添加:改成自己的目录
basedir=/opt/mysql5.6 datadir=/opt/mysql5.6/data/my_mysql
保存退出编辑。
6)最后要加上环境变量(:$PATH千万不要掉了):
命令:vi /etc/profile
export PATH=/opt/mysql/bin:$PATH
启动配置-命令: source /etc/profile
保存后退出;
7)启动服务(这里要注意下当前用户有没有权限,因为刚开始我们给这个文件的使用者指定了用户组的):
命令:
/opt/mysql5.6/support-files/mysql.server start
测试连接-命令:mysql -u root -p
初始是没有密码的,直接回车就可以进入数据库了。

可以正常使用了,接下来就和Windows操作一样了,这个MySQL版本比较低,和CentOS10直接有些兼容性问题,一般都是包不兼容,对应去下载包,指定使用规则就好了。
8)Linux中数据库开放,让宿主机连接:
现在Windows上连接不到我Linux上的MySQL的。

我们要改几个地方,先进入MySQL,使用MySQL库,然后修改user表数据

相关命令:
select host,user from user where user='root'; update user set host='%' where host='127.0.0.1';
最后还要记得
mysql> flush privileges;
可以正常连接了,可以使用;

总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。

