2006年09月17日

1. 如何加大tomcat连接数

在tomcat配置文件server.xml中的<Connector … />配置中,和连接数相关的参数有:
minProcessors:最小空闲连接线程数,用于提高系统处理性能,默认值为10
maxProcessors:最大连接线程数,即:并发处理的最大请求数,默认值为75
acceptCount:允许的最大连接数,应大于等于maxProcessors,默认值为100
enableLookups:是否反查域名,取值为:true或false。为了提高处理能力,应设置为false
connectionTimeout:网络连接超时,单位:毫秒。设置为0表示永不超时,这样设置有隐患的。通常可设置为30000毫秒。

其中和最大连接数相关的参数为maxProcessors和acceptCount。如果要加大并发连接数,应同时加大这两个参数。

web server允许的最大连接数还受制于操作系统的内核参数设置,通常Windows是2000个左右,Linux是1000个左右。Unix中如何设置这些参数,请参阅Unix常用监控和管理命令

tomcat4中的配置示例:
<Connector className="org.apache.coyote.tomcat4.CoyoteConnector"
port="8080" minProcessors="10" maxProcessors="1024"
enableLookups="false" redirectPort="8443"
acceptCount="1024" debug="0" connectionTimeout="30000" />

对于其他端口的侦听配置,以此类推。

2. tomcat中如何禁止列目录下的文件
在{tomcat_home}/conf/web.xml中,把listings参数设置成false即可,如下:
<servlet>

<init-param>
<param-name>listings</param-name>
<param-value>false</param-value>
</init-param>

</servlet>

3. 如何加大tomcat可以使用的内存

tomcat默认可以使用的内存为128MB,在较大型的应用项目中,这点内存是不够的,需要调大。

Unix下,在文件{tomcat_home}/bin/catalina.sh的前面,增加如下设置:
JAVA_OPTS=’-Xms【初始化内存大小】 -Xmx【可以使用的最大内存】’
需要把这个两个参数值调大。例如:
JAVA_OPTS=’-Xms256m -Xmx512m’
表示初始化内存为256MB,可以使用的最大内存为512MB

在企业级应用中,采用Tomcat作为应用服务器的系统不在少数,但是Tomcat作为轻量级应用服务器,它的负载能力确实有限,在系统上线后不堪重负,这时候人们都会想起集群来,可惜以往的版本做起集群来,实在不方便得很。
      Tomcat5.5在这方面作了很大的改进,我们首先可以实现Tomcat5.5的集群。
 
一、配置Tomcat
1、直接将下载的apache-tomcat-5.5.17.zip解压缩到一个驱动器根目录下,将目录名改为Tomcat5517_S1,作为集群的第一个Tomcat服务器。
2、删除Tomcat5517_S1\ webapps、Tomcat5517_S1\temp下的所有内容。
3、在Tomcat5517_S1\conf\Catalina\localhost下建立ROOT.xml文件(注意:一定要用ROOT.xml这个文件名)。添加内容:
<Context path="" docBase="发布路径" displayName="Tomcat_1"
  debug="0" privileged="true">
 
    <!– Default set of monitored resources –>
    <WatchedResource>WEB-INF/web.xml</WatchedResource>
</Context>
 
4、确认你的应用发布没有问题的情况下,运行Tomcat5517_S1\bin中的Startup.bat。
5、在浏览器中访问:
http://localhost:8080,你的应用应该可以在此Tomcat中成功发布了。
这里要注意的是:
如果你的系统中使用了Taglib尤其是c.tld,请下载最新版本的jakarta-taglibs-standard-1.1.2.zip,从中取得standard.jar、jstl.jar和c.tld,放在相应的目录下,然后修改web.xml:
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "
http://java.sun.com/dtd/web-app_2_3.dtd">
 
<web-app xmlns="
http://java.sun.com/xml/ns/j2ee"
    xmlns:xsi="
http://www.w3.org/2001/XMLSchema-instance"
    xsi:schemaLocation="
http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
    version="2.4">
</web-app>
 
其中所有的
  <taglib>
    <taglib-uri>/WEB-INF/struts-html.tld</taglib-uri>
    <taglib-location>/WEB-INF/struts-html.tld</taglib-location>
  </taglib>
 
要放在<jsp-config>元素中,像这样:
<jsp-config>
   <taglib>
     <taglib-uri>/WEB-INF/struts-template.tld</taglib-uri>
     <taglib-location>/WEB-INF/struts-template.tld</taglib-location>
   </taglib>
   <taglib>
<taglib-uri>/WEB-INF/c.tld</taglib-uri>
<taglib-location>/WEB-INF/c.tld</taglib-location>
   </taglib>
</jsp-config>

二、配置同一台机器中的Tomcat集群
1、将Tomcat5517_S1\ Catalina文件夹改名为Tomcat5517_S1\ Standalone,然后打开Tomcat5517_S1\conf\server.xml,修改几个关键的地方。
★ 远程关闭Tomcat的服务端口,原来是8005,改为10005。
★ 两个对外服务的Connector的端口:Http协议端口原来是8080,改为10001;AJP1.3协议端口原来是8009,改为10009。(这里要注意的是在开始的调试阶段我们保持http协议端口的打开状态,用于浏览器直接与此Tomcat连接,等到调试成功后,所有的客户端只允许通过apache访问,我们就要将提供Http协议的Connector关掉。)其中的redirectPort我都改成了10043。
★ 将原来的:<Engine name="Catalina" defaultHost="localhost">注释掉,打开它上面的:<Engine name="Standalone" defaultHost="localhost" jvmRoute="Tomcat1">,并且将jvmRoute的值改为Tomcat1。
★ 打开Cluster元素的注释,并且将Receiver元素的监听端口tcpListenPort改为10011。
2、修改Web.xml,加上<distributable/>,如下:
<!DOCTYPE web-app PUBLIC "-//Sun Microsystems, Inc.//DTD Web Application 2.3//EN" "
http://java.sun.com/dtd/web-app_2_3.dtd">
 
<web-app xmlns="
http://java.sun.com/xml/ns/j2ee"
 xmlns:xsi="
http://www.w3.org/2001/XMLSchema-instance"
 xsi:schemaLocation="
http://java.sun.com/xml/ns/j2ee http://java.sun.com/xml/ns/j2ee/web-app_2_4.xsd"
 version="2.4">
 <distributable/>
</web-app>
 
然后启动此Tomcat,可以看到有这样的提示信息:
2006-6-28 13:33:57 org.apache.catalina.cluster.tcp.SimpleTcpCluster start
信息: Cluster is about to start
2006-6-28 13:33:57 org.apache.catalina.cluster.tcp.ReplicationTransmitter start
信息: Start ClusterSender at cluster Standalone:type=Cluster,host=localhost with name Standalone:type=ClusterSender,host=localhost
2006-6-28 13:33:57 org.apache.catalina.cluster.mcast.McastService start
信息: Sleeping for 2000 milliseconds to establish cluster membership
2006-6-28 13:33:59 org.apache.catalina.cluster.mcast.McastService registerMBean
信息: membership mbean registered (Standalone:type=ClusterMembership,host=localhost)
2006-6-28 13:33:59 org.apache.catalina.cluster.deploy.FarmWarDeployer start
信息: Cluster FarmWarDeployer started.
2006-6-28 13:34:30 org.apache.coyote.http11.Http11BaseProtocol start
信息: Starting Coyote HTTP/1.1 on http-10001
2006-6-28 13:34:30 org.apache.jk.common.ChannelSocket init
信息: JK: ajp13 listening on /0.0.0.0:10009
2006-6-28 13:34:30 org.apache.jk.server.JkMain start
信息: Jk running ID=0 time=0/141  config=null
 
这表示Tomcat集群正常启动了。
3、复制Tomcat5517_S1文件夹,并更名为Tomcat5517_S2;然后修改Tomcat5517_S1\conf\server.xml,修改内容同上,要注意的是端口的修改:
★ 远程关闭Tomcat的服务端口,原来是8005,改为20005。
★ 两个对外服务的Connector的端口:Http协议端口原来是8080,改为20001;AJP1.3协议端口原来是8009,改为20009。其中的redirectPort我都改成了20043。
★ 将原来的:<Engine name="Catalina" defaultHost="localhost">注释掉,打开它上面的:<Engine name="Standalone" defaultHost="localhost" jvmRoute="Tomcat2">,并且将jvmRoute的值改为Tomcat2。
★ 打开Cluster元素的注释,并且将Receiver元素的监听端口tcpListenPort改为20011。
启动Tomcat2,可以看到有如下提示:
在Tomcat1中:
2006-6-28 14:25:46 org.apache.catalina.cluster.tcp.SimpleTcpCluster memberAdded
信息: Replication member added:org.apache.catalina.cluster.mcast.McastMember[tcp://192.168.1.192:20011,catalina,192.168.1.192,20011, alive=40]
 
在Tomcat2中:
2006-6-28 14:25:44 org.apache.catalina.cluster.tcp.SimpleTcpCluster memberAdded
信息: Replication member added:org.apache.catalina.cluster.mcast.McastMember[tcp://192.168.1.192:10011,catalina,192.168.1.192,10011, alive=3105085]
 
这表示两个Tomcat已经建立了集群,并保持Session同步了。

三、配置Apache

Apache2.2提供了最新的mod_proxy_balancer模块,这是我们这次实践过程中完成负载均衡的利器。安装完Apache之后,直接打开conf\httpd.conf文件:

★ 打开必要的模块:
LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
LoadModule proxy_balancer_module modules/mod_proxy_balancer.so
LoadModule proxy_http_module modules/mod_proxy_http.so

★ 在httpd.conf的最后加上:

ProxyRequests Off

ProxyPass / balancer://myCluster/
<Proxy balancer://myCluster/>
       BalancerMember ajp://localhost:10009 route=Tomcat1
       BalancerMember ajp://localhost:20009 route=Tomcat2
</Proxy>

然后启动apache,开始测试你的应用在集群环境下的表现吧!

apache2.2和tomcat5.5是一个不错的组合,可以作为开发环境或者是工作服务器。在配置前需要下载以下几个文件:
1.下载JDK
http://192.18.108.228/ECom/EComTicketServlet/BEGIN7CF7E6A4BCB54064E5D90FCCE00D7048/-2147483648/1579524843/1/732086/731822/1579524843/2ts+/westCoastFSEND/jdk-1.5.0_07-oth-JPR/jdk-1.5.0_07-oth-JPR:2/jdk-1_5_0_07-windows-i586-p.exe
2.下载apache2.2                      
http://mirror.vmmatrix.net/apache/httpd/binaries/win32/apache_2.2.2-win32-x86-no_ssl.msi
3.下载tomcat5.5.17
http://apache.justdn.org/tomcat/tomcat-5/v5.5.17/bin/apache-tomcat-5.5.17.exe

 

 

一、安装和配置JDK
    下载下来后,直接执行jdk-1.5.0_07-oth-JPR:2/jdk-1_5_0_07-windows-i586-p.exe
    实装时建议选择简单的路径,如E:\Web_Server\jdk1.5.0\
    安装最后会要求安装jre,继续下一步就行,安装路径E:\Web_Server\jre1.5.0\。
  
    装完后添加或编缉三个系统变量(已经有就编缉,没有就新建):
    在PATH变量尾加在";E:\Web_Server\jdk1.5.0\bin\"  (注意有个分号)
    新建Web_Server_HOME变量,值为 "E:\Web_Server\jdk1.5.0\"
    新建CLASSPATH变量,值为 "E:\Web_Server\jdk1.5.0\lib\tools.jar"
  
二、安装和测试apache
    在安装前如已安装了IIS,请先停止IIS服务。因为IIS和apache都默认使用80端口,否则会冲突。
    同样直接运行安装apache_2.2.2-win32-x86-no_ssl.msi,建议选择简单的路径,如E:\Web_Server\apache2.2\。安装时会要求输入一些关于这台服务器的信息,如域名、管理员邮箱,这些信息将会加入到httpd.conf文件中。
  
    安装完配置httpd.conf文件,在E:\Web_Server\apache2.2\conf\下
    用文本编缉器打开httpd.conf,在DirectoryIndex index.html后添加index.jsp
  
    测试,在IE中输入http://localhost/,如果apache工作应该可以看到"It works!"这样的页面。
  
三、安装和测试tomcat
    直接运行安装tomcat,安装路径为E:\Web_Server\tomcat5.5\
    安装完,好像步骤一,添加一个系统变量TOMCAT_HOME,变量值为"E:\Web_Server\tomcat5.5\"
    最后测试tomcat,因为tomcat默认使用了8080端口,所以在IE输入http://localhost:8080,正常工作会看见一只小猫的页面。
  
四。整合apache和tomcat
    网上很多是通过mod_jk来整合的,由于apache2.2本身已经支持tomcat了,所以这里用proxy来整合tomcat,先把apache和tomcat都停止了。然后打开httpd.conf文件,把
    LoadModule proxy_module modules/mod_proxy.so
LoadModule proxy_ajp_module modules/mod_proxy_ajp.so
前面的#号去掉,在文件最后添加

ProxyPass /images/ !
ProxyPass / ajp://127.0.0.1:8009/
ProxyPassReverse / ajp://127.0.0.1:8009/
   上面几名只是对apache进行简单的优化。
  
五、最后测试整合后的apache+tomcat
  启动apache,再启动tomcat,准备以下代码的jsp文件,以便测试。
  <%@ page contentType="text/html;charset=gb2312" %>
  <HTML>
  <HEAD>
  <TITLE>JSP测试页面</TITLE>
  </HEAD>
  <BODY>
  <%out.println("<h1>Hello World! </h1>");%>
  </BODY>
  </HTML>

保存为test.jsp
在E:\Web_Server\tomcat5.5\webapps\ROOT\下新建一个文件夹myjsp,并把test.jsp放在里面。
在IE中输入http://localhost:8080/myjsp/test.jsp
再输入http://localhost/myjsp/test.jsp
如果两次都显示Hello World!说明已经成功整合了。