`

Tomcat_单机多实例

 
阅读更多

via: http://www.importnew.com/12553.html

 

首先看到的是tomcat的目录结构,其每个文件夹有以下用途:

  • bin – 包含所有运行tomcat的二进制和脚本文件
  • lib – 包含tomcat使用的所有共享库
  • conf - 包含配置信息,如tomcat绑定的端口等
  • logs – 包含所有的日志文件
  • temp – 此目录是tomcat存放的临时文件
  • webapps – 此目录非常重要,这里存放所有的应用程序war包
  • work – 如果应用程序包含jsp文件,那么每个jsp文件会被编译转化为servlet,存放于此
 

当我们运行Tomcat时,会用到5个环境变量。他们是:

  • CATALINA_HOME
  • CATALINA_BASE
  • CATALINA_TMPDIR
  • JRE_HOME/JAVA_HOME
  • CLASSPATH

在以上列表中,CATALINA_HOME和JAVA_HOME是必要的环境变量。其它的都可以通过CATALINA_HOME来转换,是可选的。

CATALINA_HOME – 此环境变量是tomcat安装/提取的根目录。所以通过CATALINA_HOME,可以得到bin和lib目录。

CATALINA_BASE – 如果不指定则是CATALINA_HOME的值。该变量指向的目录里面包括每个运行实例需要使用自己的conf、logs、temp、webapps、work目录。

一般运行Tomcat的方法是,只设置CATALINA_HOME变量,执行startup.sh脚本,startup.sh会自动转换其它未设置的变量。

  

startup.sh设置环境变量时调用catalina.sh脚本,此脚本会读取CATALINA_BASE的值,在$CATALINA_BASE/conf目录,得到server.xml。这个文件时Tomcat的核心配置,它包含所有的配置信息,如shutdown端口,connector端口,主机名称,应用目录等。例如,Tomcat通常使用8080作为连接端口,所以我们可以通过http://localhost:8080/访问。

如果我们已经设置$CATALINA_BASE,Tomcat就会从该变量所对应的目录搜索得到server.xml。

使用此方法可以在一台机器上运行多个Tomcat实例。我们不需要改变CATALINA_HOME值,只需要在启动/关闭Tomcat之前修改CATALINA_BASE值。

创建一个名为“tomcat-instance1”的目录,从CATALINA_HOME目录中复制conf,logs,temp,webapps,work目录,修改“tomcat-instance1”目录中的conf/server.xml文件。需要修改的端口是:Shutdown port,Connector port,ajp port和Redirect port。

Shutdown port – 此端口用于关闭Tomcat。当执行shutdown.sh脚本时,它会给此端口发出一个信号,Tomcat的进程会监听此端口,如果接收到这样的信号,进程会清理退出。

Connector port - 此端口是应用对外公开发布的端口。

ajp port – Web服务器(例如Apache的httpd Server)通过此端口和Tomcat进行通信,也可以使用它设置一个负载均衡服务器。

Redirect port – 如果此Connector支持非SSL请求和接收SSL请求,Catalina会自动将请求指向到此端口。

看看示例server.xml文件:

1
2
3
4
5
6
7
8
<server port="8005" shutdown="SHUTDOWN">
    .....
    <connector
        connectiontimeout="20000"port="8080"
        protocol="org.apache.coyote.http11.Http11NioProtocol"
        redirectport="8443" />
    <connector port="8009" protocol="AJP/1.3" redirectport="8443" />
</server>

因为一个端口一旦被绑定,其它进程就不能再绑定,所以我们将这些端口修改为其它值。在tomcat-instance1/conf/server.xml文件,配置server port =8105,connector port = 8181,ajp port = 8109。

1
2
3
4
5
6
7
8
<server port="8105" shutdown="SHUTDOWN">
    .....
    <connector
        connectiontimeout="20000" port="8181"
        protocol="org.apache.coyote.http11.Http11NioProtocol"
        redirectport="81443" />
    <connector port="8109" protocol="AJP/1.3" redirectport="81443" />
</server>

现在我们可以创建两个脚本文件来启动关闭tomcat-instance1。

startup-instance1.sh

1
2
3
export CATALINA_BASE= /home/ramki/tomcat-instance1
cd $CATALINA_HOME/bin
./startup.sh

shutdown-instance1.sh

1
2
3
export CATALINA_BASE= /home/ramki/tomcat-instance1
cd $CATALINA_HOME/bin
./shutdown.sh

这里我们设置了CATALINA_BASE变量并指向新的 tomcat-instance1。因为运行tomcat的所有二进制文件都在CATALINA_HOME/bin目录,随后使用startup/shutdown脚本。

 

------------------------------------------

1.环境变量CATALINA_HOME,CATALINA_HOME2和CATALINA_BASE,CATALINA_BASE2

分别对应tomcat,tomcat2

 

2.tomcat不作修改,tomcat2作如下修改

 

2.1.修改新的tomcat中的startup.bat,把其中的CATALINA_HOME改为CATALINA_HOME2。 

2.2.修改新的tomcat中的catalina.bat,把其中的CATALINA_HOME改为CATALINA_HOME2,CATALINA_BASE改为CATALINA_BASE2。 

2.3修改conf/server.xml文件: 

2.3.1 <Server port="8005" shutdown="SHUTDOWN">把端口改为没有是使用的端口如8006。 

2.3.2 <Connector port="8080" maxHttpHeaderSize="8192" 

  maxThreads="150" minSpareThreads="25" maxSpareThreads="75" 

  enableLookups="false" redirectPort="8443" acceptCount="100" 

  connectionTimeout="20000" disableUploadTimeout="true" /> 把端口改为没有是使用的端口如8090。 

2.3.3<Connector port="8009" 

  enableLookups="false" redirectPort="8443" protocol="AJP/1.3" /> 把端口改为没有是使用的端口如8010。 

3成功!

  • 大小: 22.6 KB
  • 大小: 19.1 KB
分享到:
评论

相关推荐

    tomcat单机多实例的实现

    【标题】:Tomcat单机多实例的配置与管理 【描述】:本文详细阐述了如何在单台服务器上配置和管理多个独立的Tomcat实例,以实现应用程序的隔离和资源的有效利用。通过实例和代码,我们将深入理解单机多实例的优缺点...

    zabbix自动安装单机多tomcat实例脚本

    【Zabbix自动安装单机多Tomcat实例脚本详解】 在IT运维中,监控系统扮演着至关重要的角色,Zabbix作为一款开源的企业级监控解决方案,能够有效地监控服务器、网络设备以及应用程序的运行状态。本资源提供的"zabbix...

    nginx实现多个tomcat7直接session共享所需jar包

    标题中的“nginx实现多个tomcat7直接session共享所需jar包”指的是在分布式系统环境中,使用Nginx作为反向代理服务器,将用户请求分发到多个Tomcat7应用服务器上,同时实现用户会话(Session)在这些服务器之间的...

    solrCloud5.2.1 + tomcat7 + zookeeper3.4.6

    在完成上述步骤后,你就成功地在Windows 7环境下搭建了一个SolrCloud的基本架构,能够支持多个Solr实例在单台机器上同时运行,这为后续的分布式搜索和索引管理提供了基础。接下来,你可能还需要配置Zookeeper集群,...

    SolrCloud5.2.1+tomcat7+zookeeper3.4.6搭建教程.docx

    9. 单机版本配置完成后,启动Tomcat并访问`http://localhost:8080/solr`以验证安装是否成功。 **多Tomcat配置:** 1. 复制`tomcat7_ser1`和`solr_home_1`,分别命名为`tomcat7_ser2`、`solr_home_2`,以及`tomcat7...

    tomcat单机集群配置[借鉴].pdf

    Tomcat单机集群配置是一个常见的优化策略,尤其适用于处理高并发的Web应用。这个配置的主要目的是通过Apache HTTP Server(通常称为Apache)作为前端负载均衡器,将用户请求分发到多个在同一台服务器上的Tomcat实例...

    Tomcat +Apache实现负载均衡

    - 在同一台设备上配置多实例Tomcat和Apache,可以实现本地测试或开发环境的负载均衡,但实际生产环境中,通常会将不同的Tomcat实例部署在不同的物理或虚拟服务器上,以实现真正的分布式负载均衡。 通过以上步骤,...

    tomcat 1000/s 并发配置

    8. **负载均衡和集群部署**: 当单台服务器无法满足需求时,可以考虑使用负载均衡器分发请求到多台Tomcat实例,形成集群,进一步提升系统处理能力。 9. **监控与调优工具**: 使用JConsole、VisualVM等工具实时监控...

    apache2.4+tomcat7集群

    通过上述步骤,你可以在Windows 7环境下成功构建一个Apache 2.4 + Tomcat 7的单机垂直集群。这种配置对于测试、开发或小型生产环境都是一个实用的解决方案。然而,对于更大规模的部署,可能需要考虑更复杂的集群架构...

    tomcat集群安装配置_session.doc

    文档提到的集群搭建类型为“单机多Tomcat + Memcached共享Session”,这意味着在同一台物理服务器上部署多个Tomcat实例,并通过Memcached进行Session共享。 #### 六、软件安装步骤 1. **依赖软件安装**: - **...

    redis linux(集群&单机) + Tomcat Session共享

    本资料包提供了从单机到集群的Redis部署教程,以及与Tomcat应用服务器Session共享的解决方案。 1. **Redis单机安装**:在Linux环境下,Redis的安装通常通过编译源码或者使用包管理器如`apt`或`yum`进行。单机安装...

    SolrCloud5.2.1+tomcat7+zookeeper3.4.6搭建教程

    #### 三、配置多 Tomcat + Solr 环境 **步骤1:** 复制`tomcat7_ser1`两份,并重命名为`tomcat7_ser2`和`tomcat7_ser3`;同样地,复制`solr_home_1`两份,并重命名为`solr_home_2`和`solr_home_3`。 **步骤2:** ...

    Tomcat技术培训

    - **集群部署**:通过多个Tomcat实例共同提供服务,提高系统的可用性和负载能力。通常需要配合负载均衡器使用。 - **容器管理**:如Docker容器化部署,可以在云环境中快速部署和扩展Tomcat服务。 #### 四、Tomcat...

    redission-tomcat快速实现从单机部署到多机部署详解

    【redission-tomcat快速实现从单机部署到多机部署详解】 在许多Web应用程序的初始阶段,通常采用单机部署以简化运维和快速上线。然而,随着业务的增长和技术架构的演进,单机部署逐渐无法满足高可用性和扩展性的...

    tomcat7—官方绿色版-32位-windows

    通过复制多个Tomcat实例,并配置适当的负载均衡策略,可以实现高可用性和负载分发。 9. **JNDI资源** - Tomcat7支持JNDI(Java Naming and Directory Interface)资源,允许在多个应用之间共享数据源或其他服务。 ...

    apache-tomcat-7.0.70-src

    8. **Clustering and Load Balancing**:虽然Tomcat主要是一个单机服务器,但7.0版本引入了集群和负载均衡的支持,可以实现多个Tomcat实例之间的会话复制和请求分发。 通过阅读和分析`apache-tomcat-7.0.70-src`的...

Global site tag (gtag.js) - Google Analytics