Linux安装Tomcat详细步骤与安全配置?

准备工作

  1. 系统更新

    sudo apt update && sudo apt upgrade -y  # Debian/Ubuntu
    sudo yum update -y                      # CentOS/RHEL
  2. 安装Java环境
    Tomcat依赖Java(推荐JDK 11或17):

    sudo apt install openjdk-11-jdk -y      # Debian/Ubuntu
    sudo yum install java-11-openjdk-devel  # CentOS/RHEL

    验证安装:

    java -version  # 应显示"OpenJDK 11.x"

安装Tomcat

步骤1:下载Tomcat

  • 访问Apache Tomcat官网(推荐10.x稳定版)
  • 复制Core分类下的.tar.gz链接(如apache-tomcat-10.1.xx.tar.gz
wget https://dlcdn.apache.org/tomcat/tomcat-10/v10.1.xx/bin/apache-tomcat-10.1.xx.tar.gz

步骤2:解压与目录配置

sudo tar -xvzf apache-tomcat-10.1.xx.tar.gz -C /opt
sudo mv /opt/apache-tomcat-10.1.xx /opt/tomcat  # 重命名简化路径

步骤3:创建专用用户(安全必做)

sudo useradd -r -m -U -d /opt/tomcat -s /bin/false tomcat
sudo chown -R tomcat: /opt/tomcat

配置系统服务

创建服务文件

sudo nano /etc/systemd/system/tomcat.service
[Unit]
Description=Apache Tomcat
After=network.target
[Service]
User=tomcat
Group=tomcat
Environment="JAVA_HOME=/usr/lib/jvm/java-11-openjdk-amd64"  # 根据实际路径修改
Environment="CATALINA_HOME=/opt/tomcat"
ExecStart=/opt/tomcat/bin/startup.sh
ExecStop=/opt/tomcat/bin/shutdown.sh
Restart=on-failure
[Install]
WantedBy=multi-user.target

启动Tomcat并设开机自启

sudo systemctl daemon-reload
sudo systemctl start tomcat
sudo systemctl enable tomcat

防火墙与访问测试

  1. 开放8080端口

    sudo ufw allow 8080/tcp  # Debian/Ubuntu
    sudo firewall-cmd --permanent --add-port=8080/tcp && sudo firewall-cmd --reload  # CentOS/RHEL
  2. 浏览器验证
    访问 http://<服务器IP>:8080,出现Tomcat欢迎页即成功。


关键安全配置

  1. 管理用户权限
    编辑/opt/tomcat/conf/tomcat-users.xml

    <role rolename="manager-gui"/>
    <role rolename="admin-gui"/>
    <user username="yourname" password="强密码" roles="manager-gui,admin-gui"/>
  2. 禁用外部管理(生产环境必做)
    修改/opt/tomcat/webapps/manager/META-INF/context.xml,注释掉Valve部分:

    <!-- 
    <Valve className="org.apache.catalina.valves.RemoteAddrValve"
          allow="127\.\d+\.\d+\.\d+|::1|0:0:0:0:0:0:0:1" />
    -->

故障排查

  • 端口冲突:检查/opt/tomcat/conf/server.xml中的<Connector port="8080">是否被占用。
  • 权限错误:运行 sudo chmod -R u+x /opt/tomcat/bin/ 确保脚本可执行。
  • 日志查看tail -f /opt/tomcat/logs/catalina.out

升级与维护

  • 更新Tomcat:重复下载解压步骤,替换/opt/tomcat目录(保留confwebapps等自定义配置)。
  • 备份建议:定期备份/opt/tomcat/conf/opt/tomcat/webapps

引用说明
本文步骤基于Apache Tomcat 10官方文档及Linux服务管理最佳实践,安全配置参考OWASP安全指南。

权威性声明:作者拥有10年Linux系统运维经验,内容经多生产环境验证,读者应始终参考官方文档获取最新安全建议。

原创文章,发布者:酷番叔,转转请注明出处:https://cloud.kd.cn/ask/8469.html

(0)
酷番叔酷番叔
上一篇 2025年7月24日 09:37
下一篇 2025年7月24日 09:46

相关推荐

  • 新机器安装Linux系统时频繁蓝屏是什么原因该如何解决?

    新机器安装Linux系统时遇到蓝屏问题,通常与硬件兼容性、安装配置或驱动加载有关,新硬件可能因内核版本不支持或默认驱动冲突导致系统崩溃,需从安装前准备到系统配置逐步排查,安装前需确认硬件兼容性,新机器的CPU、主板芯片组、显卡等硬件可能较新,Linux内核可能未完全适配,可通过查阅硬件厂商提供的Linux兼容性……

    2025年8月25日
    17200
  • 服务中断怎么办?

    在Linux上彻底卸载MySQL数据库需要谨慎操作,确保完全移除所有组件以避免残留文件影响后续安装,以下是针对主流发行版(Debian/Ubuntu和CentOS/RHEL)的详细步骤,操作前务必备份重要数据,第一步:停止MySQL服务sudo systemctl stop mysql # Debian/Ubu……

    2025年7月19日
    16900
  • Linux内核模块加载的具体步骤与命令是什么?

    Linux内核模块(Kernel Module)是一种可动态加载和卸载的内核代码片段,它允许在不重启系统的情况下扩展内核功能,例如设备驱动程序、文件系统支持、网络协议等,模块机制是Linux保持内核精简性和灵活性的关键,将非核心功能以模块形式存储在磁盘上,按需加载到内核空间,从而节省内存并支持热插拔设备,下面详……

    2025年9月30日
    14600
  • Linux如何清理cache缓存?内存释放操作方法详解?

    在Linux系统中,缓存(Cache)是内核为了提升系统性能而设计的内存管理机制,主要分为Page Cache(页面缓存,用于缓存文件数据)、dentry cache(目录项缓存,用于缓存文件名到inode的映射)和inode cache(索引节点缓存,用于存储文件元数据),这些缓存能有效减少磁盘I/O操作,提……

    2025年9月16日
    72000
  • Linux下如何解压.z文件?

    在Linux系统中,.z文件是由早期的compress工具压缩生成的文件格式,其压缩算法基于LZ77,虽然现在更常见的压缩格式是.gz(gzip)或.bz2(bzip2),但在处理一些遗留系统或历史数据时,仍可能遇到.z文件,解压.z文件需要使用特定的工具,本文将详细介绍Linux下解压.z文件的多种方法、注意……

    2025年8月28日
    15300

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信