Linux安装Tomcat配置Java环境教程
时间:2026-03-20 09:36:32 307浏览 收藏
本文详细解析了在Linux系统上手动安装与配置Tomcat的核心要点,强调避开常见陷阱:必须使用完整JDK(而非仅JRE)并正确设置JAVA_HOME环境变量,通过官网下载tar.gz包解压部署以保障可控性与可维护性,精准配置tomcat-users.xml启用manager-gui角色并解除IP访问限制,以及用systemd托管时严格匹配Type=forking与PIDFile机制;每一步都直击实践中高频失败原因——从静默启动失败、403管理页拒绝访问,到systemd假成功无进程,帮你一次性打通Linux下Tomcat生产级部署的任督二脉。

Linux 上安装 Tomcat 不需要“安装包”意义上的安装,而是解压即用;但必须确保 JAVA_HOME 正确且 java -version 能输出 JDK 8+ 版本,否则 startup.sh 会静默失败或报 Cannot find ./bin/setclasspath.sh 类似错误。
确认系统已装 JDK 并配置 JAVA_HOME
Tomcat 是 Java 应用,不自带 JRE,依赖系统级 JDK。常见误区是只装了 openjdk-11-jre(只有运行时),没装 openjdk-11-jdk(含 javac 和 tools.jar,Tomcat 启动脚本会检测)。
- 运行
java -version和javac -version,两者输出版本号必须一致且 ≥ 8 - 检查
$JAVA_HOME:执行echo $JAVA_HOME,应指向 JDK 根目录(如/usr/lib/jvm/java-11-openjdk-amd64),不是jre子目录 - 若未设置,临时生效可运行:
export JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64;永久生效需写入~/.bashrc或/etc/profile
下载并解压 Tomcat,避免用系统包管理器安装
Debian/Ubuntu 的 apt install tomcat9 或 CentOS 的 yum install tomcat 会把文件散落到 /usr/share/tomcat9、/var/lib/tomcat9 等多处,权限、日志路径、启动方式均被封装,不利于调试和定制。生产环境推荐手动解压部署。
- 从官网下载二进制 tar.gz 包(如
apache-tomcat-10.1.24.tar.gz),不要下 zip 或 src 包 - 解压到非 root 目录,例如:
tar -xzf apache-tomcat-10.1.24.tar.gz -C /opt/→ 得到/opt/apache-tomcat-10.1.24 - 改属主(尤其如果你用
sudo解压过):sudo chown -R $USER:$USER /opt/apache-tomcat-10.1.24
启动前必须修改 conf/tomcat-users.xml 才能访问 Manager 页面
默认 Tomcat 禁用所有管理界面,直接访问 http://localhost:8080/manager/html 会 403。这不是端口或防火墙问题,是权限配置缺失。
- 编辑
/opt/apache-tomcat-10.1.24/conf/tomcat-users.xml - 在
内添加一行(注意:Tomcat 10+ 要求角色名用manager-gui,不是旧版的manager): - 同时需确认
webapps/manager/META-INF/context.xml中注释掉 IP 限制(或删掉allow属性),否则本地也访问不了
用 systemd 托管服务时,Type=forking 和 PIDFile 必须配对
直接运行 bin/startup.sh 是前台调试用法;生产必须用 systemd 管理生命周期。错配 Type 会导致 systemctl start tomcat 返回 success,但实际没进程,或 status 显示 inactive。
- 新建服务文件:
/etc/systemd/system/tomcat.service - 关键字段必须为:
Type=forkingPIDFile=/opt/apache-tomcat-10.1.24/logs/catalina.pidExecStart=/opt/apache-tomcat-10.1.24/bin/startup.shExecStop=/opt/apache-tomcat-10.1.24/bin/shutdown.sh - Tomcat 默认不生成
catalina.pid,需在bin/catalina.sh开头添加:CATALINA_PID="$CATALINA_BASE/logs/catalina.pid"
最常被跳过的一步:改完 tomcat-users.xml 后没重启服务,或用 startup.sh 启动却忘了先 source ~/.bashrc 让 JAVA_HOME 生效——这两个点占了 70% 的“启动成功但打不开页面”问题。
今天关于《Linux安装Tomcat配置Java环境教程》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
501 收藏
-
179 收藏
-
375 收藏
-
210 收藏
-
480 收藏
-
394 收藏
-
214 收藏
-
412 收藏
-
346 收藏
-
454 收藏
-
107 收藏
-
291 收藏
-
487 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 立即学习 543次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 立即学习 516次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 立即学习 500次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 立即学习 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 立即学习 485次学习