tomcat 6 故障解决

1、使用startup.sh 能正常启动,可以正常访问web应用,但停止tomcat时却提示拒绝链接,提示信息如下:
##############################################################

[root@web tomcat]# shutdown.sh
Using CATALINA_BASE:   /usr/local/tomcat
Using CATALINA_HOME:   /usr/local/tomcat
Using CATALINA_TMPDIR: /usr/local/tomcat/temp
Using JRE_HOME:        /usr/java/jdk1.6.0_22
Using CLASSPATH:       /usr/local/tomcat/bin/bootstrap.jar
2011-1-20 13:48:41 org.apache.catalina.startup.Catalina stopServer

严重: Catalina.stop:
java.net.ConnectException: Connection timed out
        at java.net.PlainSocketImpl.socketConnect(Native Method)
        at java.net.PlainSocketImpl.doConnect(PlainSocketImpl.java:333)
        at java.net.PlainSocketImpl.connectToAddress(PlainSocketImpl.java:195)
        at java.net.PlainSocketImpl.connect(PlainSocketImpl.java:182)
        at java.net.SocksSocketImpl.connect(SocksSocketImpl.java:366)
        at java.net.Socket.connect(Socket.java:529)
        at java.net.Socket.connect(Socket.java:478)
        at java.net.Socket.<init>(Socket.java:375)
        at java.net.Socket.<init>(Socket.java:189)
        at org.apache.catalina.startup.Catalina.stopServer(Catalina.java:424)
        at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method)
        at sun.reflect.NativeMethodAccessorImpl.invoke(NativeMethodAccessorImpl.java:39)
        at sun.reflect.DelegatingMethodAccessorImpl.invoke(DelegatingMethodAccessorImpl.java:25)
        at java.lang.reflect.Method.invoke(Method.java:597)
        at org.apache.catalina.startup.Bootstrap.stopServer(Bootstrap.java:338)
        at org.apache.catalina.startup.Bootstrap.main(Bootstrap.java

##############################################################

解决方法:

经过调试tomcat发现,tomcat在停止的时候链接的是[计算机名:8009];而我的计算机名称是[web],由于我没有在hosts里面

配置web --> 127.0.0.1,导致被无法解析,所以tomcat在停止时候无法链接该地址的8009端口,只要在/etc/hosts里增加web -->

127.0.0.1的解析就可以。
另外 如果tomcat 本身是关闭的,使用shutdown.sh 也会出现上述错误。

2、tomcat能正常启动 ,如果是多个网站,有的网站能访问,有的不能访问,log 提示信息如下:
##############################################################
信息: Deploying web application archive test.war
Exception in thread "Thread-12" java.lang.OutOfMemoryError: PermGen space
        at sun.net.www.protocol.http.Handler.openConnection(Handler.java:44)
        at sun.net.www.protocol.http.Handler.openConnection(Handler.java:39)
        at java.net.URL.openConnection(URL.java:945)
        at com.digican.pc.ss.ReviceMessageServer.run(ReviceMessageServer.java:58)
        at java.lang.Thread.run(Thread.java:662)
Exception in thread "main" java.lang.OutOfMemoryError: PermGen space
Exception in thread "Thread-28" java.lang.OutOfMemoryError: PermGen space
Exception in thread "Thread-34" java.lang.OutOfMemoryError: PermGen space
[root@web logs]# 

##############################################################
解决方法:

经过调试tomcat发现,此问题是由于tomcat本身默认的内存较小造成的,解决方法分两种:

如将内存增加至1024M

第一种: 使用startup.sh 启动tomcat的解决方法

修改 TOMCAT_HOME/bin/catalina.sh

在“echo "Using CATALINA_BASE:   $CATALINA_BASE"”上面加入以下行:
JAVA_OPTS="-server -XX:PermSize=512M -XX:MaxPermSize=1024m"

重启tomcat

 使用ps -aux 能得到  -XX:PermSize=256M -XX:MaxPermSize=1024m 这样的信息,说明成功。
 
第二种:使用server tomcatd start 启动tomcat的解决方法

修改 /etc/init.d/tomcatd

在“"-Djava.io.tmpdir=$TMP_DIR \
    -pidfile $PID_FILE \”
   
    之间增加一行
    “-XX:PermSize=256M -XX:MaxPermSize=1024m \”
   
    修改后的内容如下:
    “"-Djava.io.tmpdir=$TMP_DIR \
    -XX:PermSize=256M -XX:MaxPermSize=1024m \
    -pidfile $PID_FILE \”
   
    之后重启tomcat
   
    使用ps -aux 能得到  -XX:PermSize=256M -XX:MaxPermSize=1024m 这样的信息,说明成功。