CentOS 7 安装Java8 + Tomcat8

2024-06-18 22:18
文章标签 java 安装 centos tomcat8

本文主要是介绍CentOS 7 安装Java8 + Tomcat8,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

按百度上搜到的教程安装出现各种Bug。在此记录一下自己亲自动手操作的步骤,并加上我踩坑解决Bug的过程,希望对有需要的人有所帮助。

一、 环境介绍

Vultr VPS 
CentOS 7 X64
Python3(Main)+Python2
yum+wget

##二、 目标环境 ##
Java8
Apache Tomcat8
##三. 操作步骤##

1. Java8 安装
1). 使用yum进行Java8的安装。

yum -y list java* ## 列出所有java版本
yum -y install java-1.8.0-openjdk* ## 安装1.8版本Java

发现报错:

[root@Cyril ~]# yum -y list java*
Loaded plugins: fastestmirror
Loading mirror speeds from cached hostfileFile "/usr/libexec/urlgrabber-ext-down", line 28except OSError, e:

这里是因为本人安装了Python3的环境,将yum的运行环境改为python2重新运行yum安装即可。参考 yum安装软件报错:SyntaxError:invalid syntax

vi /bin/yum # 将yum中的#!/usr/bin/python 改为 #!/usr/bin/python2
yum -y list java* ## 列出所有java版本
yum -y install java-1.8.0-openjdk* ## 安装1.8版本Java

2). 检查安装

java -version # 检查java版本

这里写图片描述
到此,java8安装成功。

2. 安装Tomcat8
1). wget下载Tomcat包并执行安装:

wget http://mirrors.shu.edu.cn/apache/tomcat/tomcat-8/v8.0.53/bin/apache-tomcat-8.0.53.tar.gz ## 下载包
mkdir -p /opt/soft
tar -zxvf apache-tomcat-8.0.33.tar.gz -C /opt/soft ## 	解压包
cd /opt/soft/apache-tomcat-8.0.33/bin/
./startup.sh ## 启动Tomcat

2). 配置防火墙
将8080端口,添加到防火墙白名单。端口可任意设置,且Tomcat端口配置一致即可。注意不要设置与其它服务端口冲突。

firewall-cmd --zone=public --add-port=8080/tcp --permanent # 去掉--permanent将只是临时修改,重启后设置被重置。
firewall-cmd --reload # 加载更新后的防火墙配置

执行时firewall-cmd命令时出现错误:
这里写图片描述
这是由于本教程环境安装的Python版本非系统自带的2.7导致该文件执行有误。
解决方法:参考 执行firewall-cmd命令提示“ModuleNotFoundError:no module named ‘gi’ ”

vi /usr/bin/firewall-cmd  
## 将第一行#!/usr/bin/python -Es 修改为 #!/usr/bin/python2.7 -Es  保存并退出再次执行firewall-cmd即可。

也可以直接打开防火墙配置文件/etc/firewalld/zones/public.xml,手动添加端口(如8080/tcp)。注意手动添加后需要使用"firewall-cmd --load"命令载入更新:
这里写图片描述
3). 测试Tomcat远程访问
到这里,貌似Tomcat8已正常安装配置完毕,但实际在测试远程访问Tomcat服务器时,报如下错误:
这里写图片描述
查看防火墙和端口状态都正常:
这里写图片描述
运行关闭防火墙服务命令报错:

#Job for firewalld.service failed because the control process exited with error

还是由于Python版本惹的祸,在文件/usr/bin/firewall-cmd更改头为:

#!/usr/bin/python2.7 -Es

也可直接打开防火墙配置文件,手动添加修改,修改配置文件后需要load配置文件或重启防火墙。任何情况下不建议关闭禁用防火墙的粗暴方式解决问题!

systemctl stop firewalld.service # 关闭防火墙
systemctl stop firewalld.service # 开启防火墙

参考 安装完python3版本后,防火墙无法启动Job for firewalld.service failed because the control process exited with error

4). 重新设置Tomcat
防火墙设置Ok后,无法远程访问Tomcat服务器的问题仍未解决。
后面发现Tomcat安装完毕后,需要新建用户并授予权限。关于初始用户:tomcat both以及role1,虽然不使用但是也要修改密码,否则新建的用户也会被拒绝访问!
接下来进行Tomcat Manager用户配置。参考Tomcat Manager用户配置详解。这里采用手动修改配置文件方式为Tomcat增加用户,命令添加方式请读者自行百度。
打开编辑Tomcat 用户配置文件:

vi [Tomcat安装目录]/conf/tomcat-users.xml

初始配置如下:
这里写图片描述
修改为如下(或者可以直接将初始配置中“must-be-changed”更改为用户密码)

<role rolename="manager-gui"/>
<role rolename="manager-script"/>
<role rolename="manager-jmx"/>
<role rolename="manager-status"/>
<role rolename="admin-gui"/>
<role rolename="admin-script"/>
<user username="test" password="test" roles="manager-gui,manager-script,manager-jmx,manager-status,admin-gui,admin-script"/>---------------------本文来自 t0mCl0nes 的CSDN 博客 ,全文地址请点击:https://blog.csdn.net/fly_leopard/article/details/79654254?utm_source=copy 

配置完重启Tomcat服务,在远程浏览器尝试访问仍显示如上图相同的错误。检查防火墙和Apache Tomcat状态无异常,对应的端口也在防火墙白名单内,只能让服务器硬件重启,发现仍无法连接。
5). 重新配置Java环境
在运行Tomcat ./startup.sh 的时候发现有显示jre路径,考虑是否和java环境变量有关,于是开始配置java-tomcat环境变量:

find / -name "jdk1.8*"  # 查找jdk目录
vi /etc/profile # 查看系统环境变量配置文件

在profile文件中最后面加上如下配置

export JAVA_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.181-3.b13.el7_5.x86_64/
export JRE_HOME=/usr/lib/jvm/java-1.8.0-openjdk-1.8.0.181-3.b13.el7_5.x86_64/jre
export CLASSPATH=.:$JAVA_HOME/lib/dt.jar:$JAVA_HOME/lib/tools.jar:$JRE_HOME/lib:$CLASSPATH
export PATH=$JAVA_HOME/bin:$PATH

保存退出profile文件后记得使用source命令更新配置文件

source /etc/profile

再次尝试运行./startup.sh 显示如下,说明java环境变量配置成功:
这里写图片描述
重启服务器(Tomcat会自动重启),在远程浏览器输入服务器IP地址,发现成功访问Tomcat欢迎页面
这里写图片描述

在这里列出Tomcat 文件目录解析:

  • bin:主要是开启、改变Tomcat的命令
  • conf:存放一些配置文件
  • lib:存放一些库文件,就是一些jar包
  • logs:存放运行产生的日志文件
  • temp:保存运行的时产生一些临时文件
  • webapps:部署要运行的应用,就存放这个目录下
  • work:运行过程产生的class文件

[Tomcat安装目录]/bin/conf/server.xml 是服务器配置文件,关于服务器端口设置在此文件中配置。博主在公司内网测试时发现8080端口访问受限,更改为其它端口(建议9000+的端口以免冲突)访问成功。
到此成功实现CentOS 7系统安装Java8、Tomcat8。

====================================

四、安装步骤总结

  1. 安装Java 8
  • 指定yum命令以python2 环境运行
  • 使用yum下载安装jdk
  • 配置java环境,修改/etc/profile配置文件
  • 使用source命令更新配置文件
  • 检查JDK安装是否成功
  1. 安装Tomcat 8
  • 指定firewall-cmd命令以python2 环境运行
  • 使用wget下载包
  • tar解压到安装目录
  • 进行Tomcat Manager用户配置
  • 将端口加入到防火墙白名单
  • 检查防火墙状态
  • 检查白名单状态
  • 检查端口状态
  • 运行./startup.sh开启tomcat
  • 完成Tomcat安装及配置

这篇关于CentOS 7 安装Java8 + Tomcat8的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1073206

相关文章

JVM 的类初始化机制

前言 当你在 Java 程序中new对象时,有没有考虑过 JVM 是如何把静态的字节码(byte code)转化为运行时对象的呢,这个问题看似简单,但清楚的同学相信也不会太多,这篇文章首先介绍 JVM 类初始化的机制,然后给出几个易出错的实例来分析,帮助大家更好理解这个知识点。 JVM 将字节码转化为运行时对象分为三个阶段,分别是:loading 、Linking、initialization

Spring Security 基于表达式的权限控制

前言 spring security 3.0已经可以使用spring el表达式来控制授权,允许在表达式中使用复杂的布尔逻辑来控制访问的权限。 常见的表达式 Spring Security可用表达式对象的基类是SecurityExpressionRoot。 表达式描述hasRole([role])用户拥有制定的角色时返回true (Spring security默认会带有ROLE_前缀),去

浅析Spring Security认证过程

类图 为了方便理解Spring Security认证流程,特意画了如下的类图,包含相关的核心认证类 概述 核心验证器 AuthenticationManager 该对象提供了认证方法的入口,接收一个Authentiaton对象作为参数; public interface AuthenticationManager {Authentication authenticate(Authenti

Spring Security--Architecture Overview

1 核心组件 这一节主要介绍一些在Spring Security中常见且核心的Java类,它们之间的依赖,构建起了整个框架。想要理解整个架构,最起码得对这些类眼熟。 1.1 SecurityContextHolder SecurityContextHolder用于存储安全上下文(security context)的信息。当前操作的用户是谁,该用户是否已经被认证,他拥有哪些角色权限…这些都被保

Spring Security基于数据库验证流程详解

Spring Security 校验流程图 相关解释说明(认真看哦) AbstractAuthenticationProcessingFilter 抽象类 /*** 调用 #requiresAuthentication(HttpServletRequest, HttpServletResponse) 决定是否需要进行验证操作。* 如果需要验证,则会调用 #attemptAuthentica

Spring Security 从入门到进阶系列教程

Spring Security 入门系列 《保护 Web 应用的安全》 《Spring-Security-入门(一):登录与退出》 《Spring-Security-入门(二):基于数据库验证》 《Spring-Security-入门(三):密码加密》 《Spring-Security-入门(四):自定义-Filter》 《Spring-Security-入门(五):在 Sprin

Java架构师知识体认识

源码分析 常用设计模式 Proxy代理模式Factory工厂模式Singleton单例模式Delegate委派模式Strategy策略模式Prototype原型模式Template模板模式 Spring5 beans 接口实例化代理Bean操作 Context Ioc容器设计原理及高级特性Aop设计原理Factorybean与Beanfactory Transaction 声明式事物

Zookeeper安装和配置说明

一、Zookeeper的搭建方式 Zookeeper安装方式有三种,单机模式和集群模式以及伪集群模式。 ■ 单机模式:Zookeeper只运行在一台服务器上,适合测试环境; ■ 伪集群模式:就是在一台物理机上运行多个Zookeeper 实例; ■ 集群模式:Zookeeper运行于一个集群上,适合生产环境,这个计算机集群被称为一个“集合体”(ensemble) Zookeeper通过复制来实现

CentOS7安装配置mysql5.7 tar免安装版

一、CentOS7.4系统自带mariadb # 查看系统自带的Mariadb[root@localhost~]# rpm -qa|grep mariadbmariadb-libs-5.5.44-2.el7.centos.x86_64# 卸载系统自带的Mariadb[root@localhost ~]# rpm -e --nodeps mariadb-libs-5.5.44-2.el7

Centos7安装Mongodb4

1、下载源码包 curl -O https://fastdl.mongodb.org/linux/mongodb-linux-x86_64-rhel70-4.2.1.tgz 2、解压 放到 /usr/local/ 目录下 tar -zxvf mongodb-linux-x86_64-rhel70-4.2.1.tgzmv mongodb-linux-x86_64-rhel70-4.2.1/