Ubuntu还是CentOS?如何选择最佳操作系统版本?

Apache Tomcat 是一款开源的轻量级 Web 应用服务器,广泛用于部署 Java Servlet 和 JSP 项目,在 Linux 系统上部署 Tomcat 可提供稳定高效的运行环境,本文将详细讲解部署流程,涵盖环境准备、安装配置、安全优化及故障排查,确保您快速搭建生产级服务。

  • 硬件:至少 1GB 内存,2GB 磁盘空间。
  • 权限:使用 sudo 权限的账户。
  1. 安装 Java
    Tomcat 依赖 Java 环境,推荐安装 OpenJDK 11:

    sudo apt update && sudo apt install openjdk-11-jdk  # Ubuntu
    # CentOS: sudo yum install java-11-openjdk-devel
    java -version  # 验证安装,输出版本信息即成功

安装 Tomcat

  1. 下载 Tomcat
    访问 Apache Tomcat 官网(确保链接权威性),选择 Tomcat 10.x(稳定版),复制 Binary Distributions → Core 的 tar.gz 链接。

    wget https://dlcdn.apache.org/tomcat/tomcat-10/v10.1.24/bin/apache-tomcat-10.1.24.tar.gz
  2. 解压与目录配置

    sudo tar -xzvf apache-tomcat-*.tar.gz -C /opt  # 解压到/opt目录
    sudo mv /opt/apache-tomcat-10.1.24 /opt/tomcat  # 重命名为tomcat
  3. 创建专用用户(安全必选)

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

配置与启动

  1. 设置环境变量
    编辑 ~/.bashrc/etc/profile

    export CATALINA_HOME=/opt/tomcat
    export PATH=$PATH:$CATALINA_HOME/bin

    生效配置:source ~/.bashrc

  2. 启动 Tomcat 并测试

    sudo -u tomcat $CATALINA_HOME/bin/startup.sh  # 以tomcat用户启动
    • 访问测试:浏览器输入 http://<服务器IP>:8080,出现 Tomcat 欢迎页即成功。
    • 停止服务:$CATALINA_HOME/bin/shutdown.sh

高级配置

  1. 设为系统服务(开机自启)
    创建服务文件 /etc/systemd/system/tomcat.service

    [Unit]
    Description=Apache Tomcat
    After=network.target
    [Service]
    User=tomcat
    Group=tomcat
    Environment="CATALINA_HOME=/opt/tomcat"
    ExecStart=/opt/tomcat/bin/catalina.sh run
    ExecStop=/opt/tomcat/bin/shutdown.sh
    Restart=on-failure
    [Install]
    WantedBy=multi-user.target

    启用服务:

    sudo systemctl daemon-reload
    sudo systemctl start tomcat
    sudo systemctl enable tomcat
  2. 修改默认端口(可选)
    编辑 /opt/tomcat/conf/server.xml,找到 Connector port="8080",修改端口(如 808080)。

  3. 防火墙放行端口

    sudo ufw allow 8080/tcp  # Ubuntu
    # CentOS: sudo firewall-cmd --permanent --add-port=8080/tcp && firewall-cmd --reload

安全加固

  1. 管理后台安全

    • 删除默认用户:注释 /opt/tomcat/conf/tomcat-users.xml 中的示例账户。
    • 自定义强密码账户:
      <user username="admin" password="YourStrongPassword!" roles="manager-gui,admin-gui"/>
  2. 禁用未用功能
    删除 /opt/tomcat/webapps 下的默认应用(如 docsexamples),减少攻击面。

  3. 定期更新
    通过 Apache 官网 关注安全公告,及时升级版本。


常见问题解决

  • 端口冲突
    使用 netstat -tuln | grep 8080 检查占用,修改 server.xml 中的端口。
  • 权限错误
    确保 /opt/tomcat 所属用户为 tomcat,执行 sudo chmod -R u+x /opt/tomcat/bin
  • 无法访问管理页面
    检查 manager-gui 角色是否分配,或 IP 限制(配置 Contextallow 属性)。

通过上述步骤,您已在 Linux 上完成 Tomcat 的标准化部署与安全加固,建议结合 Nginx 反向代理提升性能,并定期备份 confwebapps 目录,实践时请严格遵循官方文档,确保生产环境稳定性。

引用说明

  • Apache Tomcat 官方文档:https://tomcat.apache.org/tomcat-10.1-doc/
  • OpenJDK 安装指南:https://openjdk.org/install/
  • Linux 系统服务配置:https://www.freedesktop.org/software/systemd/man/systemd.service.html

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

(0)
酷番叔酷番叔
上一篇 2025年7月25日 07:17
下一篇 2025年7月25日 07:34

相关推荐

  • Linux中创建文件夹目录的具体步骤和命令是什么?

    在Linux操作系统中,建立文件夹目录(即创建目录)是日常管理和系统维护的基础操作,主要通过mkdir命令实现,mkdir是“make directory”的缩写,支持灵活的参数配置,能够满足单目录创建、多级嵌套目录创建、权限设置等需求,本文将详细介绍mkdir命令的使用方法、常用参数、高级技巧及常见问题解决……

    2025年9月24日
    15100
  • 如何快速查看已装Boost包?

    在Linux系统中卸载Boost库需要根据其安装方式选择对应方法,Boost通常通过包管理器安装或源码编译安装,以下是详细卸载步骤及注意事项:通过包管理器卸载(推荐方式)若Boost通过系统包管理器(如APT、YUM/DNF、Zypper)安装,使用对应命令卸载:Debian/Ubuntu(APT)# 卸载所有……

    2025年7月5日
    15200
  • Linux VPS如何登录?新手入门详细步骤与操作技巧全攻略

    登录Linux VPS(虚拟专用服务器)是进行服务器管理的基础操作,通常通过SSH(Secure Shell)协议实现安全远程连接,本文将详细介绍登录Linux VPS的完整流程、不同场景下的操作方法、安全配置建议及常见问题排查,帮助用户顺利完成连接并保障服务器安全,登录前的准备工作在尝试登录Linux VPS……

    2025年9月27日
    12600
  • 如何用U盘启动Linux?具体操作步骤有哪些?

    要用U盘启动Linux,需经历准备阶段、制作启动盘、设置BIOS/UEFI、启动安装等步骤,以下是详细操作指南:准备阶段下载Linux镜像文件:访问Linux发行版官网(如Ubuntu、Fedora、Deepin等),下载ISO镜像文件(推荐选择LTS长期支持版本,更稳定),确保镜像完整,可通过校验和(如SHA……

    2025年9月20日
    12500
  • linux中如何运行python脚本

    Linux系统中运行Python脚本是一项常见的任务,无论是进行数据处理、自动化任务还是开发应用程序,了解如何在Linux环境中执行Python脚本都是非常有用的技能,以下将详细介绍在Linux中运行Python脚本的多种方法、相关配置以及常见问题的解决方案,确保Python已安装在开始运行Python脚本之前……

    2025年8月14日
    12500

发表回复

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

联系我们

400-880-8834

在线咨询: QQ交谈

邮件:HI@E.KD.CN

关注微信