java

关注公众号 jb51net

关闭
首页 > 软件编程 > java > Linux下Java项目基础环境搭建

Linux环境下Java项目基础环境搭建过程

作者:米糕闯编程

文章主要讲述了在Linux系统下安装和配置JDK、Tomcat、MySQL的过程,包括使用tar、rpm、yum命令进行软件安装,修改环境变量,启动服务,配置防火墙,以及初始化MySQL数据库等步骤

一、下载解压JDK和Tomcat(JDK为必备环境)

Linux软件安装方法:

1、tar:解压安装

2、rpm:直接安装

3、yum:在线安装

一般建议解压安装;JDK、Tomcat、MYSQL、maven的版本一般都建议与开发环境保持一致,并且要注意对应的Tomcat版本所支持的JDK版本,官网上几乎都能看到版本对应信息;

JDK安装:先去官网找到对应的版本,我这边做测试用的项目是比较老的,所以用的JDK8

Java Downloads | Oracle

可以在官网上找到自己的版本:

我的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,

<!-- 以下三行为开启界面用户使用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管理,一般会建一个专门的用户管理数据库;

添加用户组:

创建数据文件夹(本地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;

可以正常连接了,可以使用;

总结

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

您可能感兴趣的文章:
阅读全文