**一、安装Java开发工具包(JDK)**
首先确保系统已经正确安装了 Java 开发工具包 ( JDK ) 。以 Ubuntu 操作系统为例,在终端执行以下命令来添加官方的 Oracle PPA 并更新软件源列表:
bash
sudo add-apt-repository ppa:webupd8team/java
sudo apt-get update
然后通过如下指令安装Oracle JDK 8或更高版本:
bash
sudo apt install oracle-javaXX-installer # 将 XX 替换为实际所需的 java 版本号
java -version # 验证是否成功安装和配置默认jdk。
**二、下载与解压Tomcat压缩文件**
访问 Apache 官方网站获取最新版或者其他指定版本的 tomcat 压缩包,并将其上传至您的Linux服务器。
例如使用wget从官网直接下载到 /opt 目录下:
bash
cd /opt
sudo wget http://apache.mirrors.ionfish.org/tomcat/tomcat-X.Y.Z/bin/apache-tomcat-X.Y.Z.tar.gz # X.Y.Z代表具体的tomcat版本
sudo tar zxf apache-tomcat-X.Y.Z.tar.gz
接下来对已解压出的目录进行重命名以便区分不同Tomcat实例:
bash
mv apache-tomcat-X.Y.Z tomcat1 # 这里将第一个Tomcat命名为"tomcat1"
# 若需再创建第二个Tomcat,则重复上述下载/解压过程后改名如: mv apache-tomcat-X.Y.Z tomcat2
**三、修改端口号和服务启动脚本**
每个运行中的Tomcat都需要不同的监听端口避免冲突,通常情况下我们需要更改conf/server.xml 文件内的 Connector 节点定义:
对于 `tomcat1` 的 server.xml ,找到Connector标签并将port属性值更改为非标准端口(比如原本是8080则可设置成8090) :
xml
<Server port="8005" shutdown="SHUTDOWN">
...
<Service name="Catalina">
...
<Connector port="8090" protocol="HTTP/1.1"
connectionTimeout="20000"
redirectPort="8443" />
...
</Service>
</Server>
针对其他所有要部署的Tomcat实例均按照此法分别变更相应端口。
另外,请分别为每一个Tomcat编写Systemd启动脚本来管理和控制其生命周期。例如, 在 `/etc/systemd/system/tomcat1.service` 创建一个新单元文件内容可能类似这样:
ini
[Unit]
Description=Apache Tomcat Server for Instance One
After=syslog.target network.target
[Service]
Type=forking
User=tomcat # 更改为此处应使用的用户,默认可以新建名为“tomcat”的系统账户
Group=sudo # 或您希望分配给该用户的组
ExecStart=/opt/tomcat1/bin/startup.sh
ExecStop=/bin/bash -c '"/opt/tomcat1/bin/shutdown.sh"'
RestartSec=10s
KillMode=process
Environment='CATALINA_PID=/var/run/tomcat1.pid'
SysLogIdentifier=%n
[Install]
WantedBy=default.target
同样地,若存在更多个Tomcat实例时,为其各自建立相应的systemd service unit即可。
**四、注册并启用 Systemd Service**
应用以上改动之后,依次执行下列命令使各个新的 systemd 单元生效以及开启自动随开机自启功能:
bash
sudo systemctl daemon-reload
sudo systemctl enable tomcat1
sudo systemctl start tomcat1
# 对于其它实例,譬如 "tomcat2", 则替换上面的服务名称继续操作.
最后验证各独立Tomcat实例的状态及其所绑定的不同网络接口及端口情况,确认一切正常无误便完成了多台Tomcat服务器在Linux下的部署工作。同时你还可以结合Nginx或其他反向代理作为前端负载均衡器进一步优化你的分布式架构布局。