检测tomcat服务状态,自动重启Tomcat(java兑现)

检测tomcat服务状态,自动重启Tomcat(java实现)
原理很简单。 在机器上做一个测试的文件。如果我们的程序能够读取到这个文件,则证明运行正常,可简单实现Tomcat HA.

import java.net.URL; 
 
import java.net.URLConnection; 
 
import java.util.Date; 
 
  
 
public class Detector { 
 
    private static void keepTomcatAlive() throws NullPointerException { 
 
       String s; 
 
       String t = new String("tomcat5.exe"); 
 
       boolean isTomcatAlive = false; 
 
       java.io.BufferedReader in; 
 
       try { 
 
           URL url = new URL("http://localhost/heartbeat.htm"); 
 
           URLConnection con = url.openConnection(); 
 
           in = new java.io.BufferedReader(new java.io.InputStreamReader(con 
 
                  .getInputStream())); 
 
           con.setConnectTimeout(1000); 
 
           con.setReadTimeout(4000); 
 
           while ((s = in.readLine()) != null) { 
 
              if (s.length() > 0) { 
 
                  // 如果能够读取到页面则证明可用 
 
                  return; 
 
              } 
 
           } 
 
           in.close(); 
 
       } catch (Exception ex) { 
 
       } 
 
  
 
       try { 
 
           java.lang.Process p = java.lang.Runtime.getRuntime().exec( 
 
                  "tasklist"); 
 
  
 
           in = new java.io.BufferedReader(new java.io.InputStreamReader(p 
 
                  .getInputStream())); 
 
  
 
           while ((s = in.readLine()) != null) { 
 
              if (s.startsWith(t)) { 
 
                  isTomcatAlive = true; 
 
                  break; 
 
              } 
 
           } 
 
           in.close(); 
 
       } catch (Exception e) { 
 
           e.printStackTrace(); 
 
       } 
 
       if (isTomcatAlive) { 
 
           System.out.println("<" + new Date() 
 
                  + "> Tomcat is alive but not response!"); 
 
           stopTomcat(); 
 
       } 
 
       startTomcat(); 
 
    } 
 
  
 
    public static void stopTomcat() { 
 
       try { 
 
           java.lang.Process p = java.lang.Runtime.getRuntime().exec( 
 
                  "net stop \"Apache Tomcat\""); 
 
           java.io.BufferedReader in = new java.io.BufferedReader( 
 
                  new java.io.InputStreamReader(p.getInputStream())); 
 
           String s; 
 
           String t = "成功停止"; 
 
           boolean restart = false; 
 
           while ((s = in.readLine()) != null) { 
 
              if (s.indexOf(t) != -1) { 
 
                  restart = true; 
 
                  break; 
 
              } 
 
           } 
 
           System.out.println("<" + new Date() + "> Tomcat is stop " 
 
                  + (restart ? "OK" : "ERROR")); 
 
       } catch (Exception e) { 
 
           e.printStackTrace(); 
 
       } 
 
    } 
 
  
 
    public static void startTomcat() { 
 
       try { 
 
           java.lang.Process p = java.lang.Runtime.getRuntime().exec( 
 
                  "net stop \"Apache Tomcat\""); 
 
       } catch (Exception e) { 
 
           e.printStackTrace(); 
 
       } 
 
       try { 
 
           java.lang.Process p = java.lang.Runtime.getRuntime().exec( 
 
                  "net start \"Apache Tomcat\""); 
 
           java.io.BufferedReader in = new java.io.BufferedReader( 
 
                  new java.io.InputStreamReader(p.getInputStream())); 
 
           String s; 
 
           String t = "启动成功"; 
 
           boolean restart = false; 
 
           while ((s = in.readLine()) != null) { 
 
              if (s.indexOf(t) != -1) { 
 
                  restart = true; 
 
                  break; 
 
              } 
 
           } 
 
           System.out.println("<" + new Date() + "> Tomcat is start " 
 
                  + (restart ? "OK" : "ERROR")); 
 
       } catch (Exception e) { 
 
           e.printStackTrace(); 
 
       } 
 
    } 
 
  
 
    public static void main(String[] args) { 
 
       while (true) { 
 
           try { 
 
              Detector.keepTomcatAlive(); 
 
              Thread.sleep(30000); 
 
           } catch (Exception ex) { 
 
  
 
           } 
 
       } 
 
    } 
} 





另一种方式:监控日志

由于tomcat部署的应用,在客户使用的过程中,每过五六天总会吊死成僵尸进程,查看日志为无效的变元,搜遍网络,尝试了很多办法也没有解决此问题。同时不能更换web容器,因为会增加成本,只好用java写了个监控程序,目前正在测试中

import java.net.URL; 
 
import java.net.URLConnection; 
 
import java.text.SimpleDateFormat; 
 
import java.util.Date; 
 
import org.apache.log4j.Logger; 
 
import org.apache.log4j.PropertyConfigurator; 
 
import java.util.TimeZone; 
 
  
 
  
 
/** 
 
 * NAME : tomcat.java 
 
 * FUNCTION : 监控服务器tomcat状态 
 
 * PROGRAMMED : TELSTAR/jlsu 
 
 * DATE(ORG) : 20090109 
 
 * PROJECT : TELSTAR 
 
 * OS : HP-UNIX 
 
 * HISTORY : 
 
 */ 
 
  
 
public class TomcatDetector { 
 
  
 
    private long sJKdate; 
 
  
 
    public TomcatDetector() { 
 
       Date now = new Date(); 
 
       sJKdate = now.getTime(); 
 
  
 
    } 
 
  
 
    private static final Logger logger = Logger.getLogger(TomcatDetector.class); 
 
  
 
    private static void keepTomcatAlive() throws NullPointerException { 
 
    String s; 
 
    boolean isTomcatAlive = false; 
 
    java.io.BufferedReader in; 
 
     Date now = new Date(); 
 
        long lnow = now.getTime(); 
 
        Date selDate = new Date(); 
 
        SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
 
        df.setTimeZone(TimeZone.getTimeZone("Etc/GMT-8")); 
 
        String sSel_date = df.format(selDate); 
 
    try { 
 
      URL url = new URL("http://133.128.4.7:8080/index.jsp"); 
 
      URLConnection con = url.openConnection(); 
 
      in = new java.io.BufferedReader(new java.io.InputStreamReader(con.getInputStream())); 
 
      con.setConnectTimeout(1000); 
 
      con.setReadTimeout(4000); 
 
      while ((s = in.readLine()) != null) { 
 
        if (s.length() > 0) { 
 
          // 如果in.readLine的内容不为空,则证明当前的tomcat容器可用,不过操作直接返回 
 
          return; 
 
        } 
 
      } 
 
      in.close(); 
 
    } catch (Exception ex) { 
 
    } 
 
    try { 
 
      java.lang.Process p = java.lang.Runtime.getRuntime().exec("ps -ef | grep Djava.uti | grep -v tail | grep -v vi | grep -v grep | awk '{print $2}'"); 
 
      in = new java.io.BufferedReader(new java.io.InputStreamReader(p.getInputStream())); 
 
      while ((s = in.readLine()) != null) { 
 
          isTomcatAlive = true; 
 
          break; 
 
      } 
 
      in.close(); 
 
    } catch (Exception e) { 
 
      e.printStackTrace(); 
 
    } 
 
    if (isTomcatAlive) { 
 
      logger.debug(sSel_date + "> Tomcat is alive but not response!"); 
 
      stopTomcat(); 
 
    } 
 
    startTomcat(); 
 
  } 
 
  
 
    public static void stopTomcat() { 
 
         Date now = new Date(); 
 
        long lnow = now.getTime(); 
 
        Date selDate = new Date(); 
 
        SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
 
        df.setTimeZone(TimeZone.getTimeZone("Etc/GMT-8")); 
 
        String sSel_date = df.format(selDate); 
 
    try { 
 
         logger.debug("------------------开始杀死僵尸tomcat---------------------"); 
 
     
 
    java.lang.Process p = java.lang.Runtime.getRuntime().exec("kill -9 `ps -ef | grep Djava.uti | grep -v tail | grep -v vi | grep -v grep | awk '{print $2}'`"); 
 
    java.lang.Process p1 = java.lang.Runtime.getRuntime().exec("ps -ef |grep java | grep -v vi | grep -v tail | grep -v grep"); 
 
      java.io.BufferedReader in = new java.io.BufferedReader(new java.io.InputStreamReader(p1.getInputStream())); 
 
      String s; 
 
      String t = "Djava"; 
 
      boolean restart = false; 
 
      while ((s = in.readLine()) != null) { 
 
        if (s.indexOf(t) == -1) { 
 
          restart = true; 
 
          break; 
 
        } 
 
      } 
 
      logger.debug( sSel_date + "> Tomcat is stop " + (restart ? "OK" : "ERROR")); 
 
    } catch (Exception e) { 
 
      e.printStackTrace(); 
 
    } 
 
  } 
 
  
 
    public static void startTomcat() { 
 
     Date now = new Date(); 
 
        long lnow = now.getTime(); 
 
        Date selDate = new Date(); 
 
        SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
 
        df.setTimeZone(TimeZone.getTimeZone("Etc/GMT-8")); 
 
        String sSel_date = df.format(selDate); 
 
    try { 
 
        java.lang.Process p = java.lang.Runtime.getRuntime().exec("kill -9 `ps -ef | grep Djava.uti | grep -v tail | grep -v vi | grep -v grep | awk '{print $2}'`"); 
 
         
 
    } catch (Exception e) { 
 
      e.printStackTrace(); 
 
    } 
 
    try { 
 
         logger.debug("------------------开始重启---------------------"); 
 
        java.lang.Process p1 = java.lang.Runtime.getRuntime().exec("/telstar/tomcat/bin/./startup.sh &"); 
 
      java.io.BufferedReader in = new java.io.BufferedReader(new java.io.InputStreamReader(p1.getInputStream())); 
 
      String s; 
 
      String t = "tomcat"; 
 
      boolean restart = false; 
 
      while ((s = in.readLine()) != null) { 
 
        if (s.indexOf(t) != -1) { 
 
          restart = true; 
 
          break; 
 
        } 
 
      } 
 
      logger.debug( sSel_date + "> Tomcat is start " + (restart ? "OK" : "ERROR")); 
 
    } catch (Exception e) { 
 
      e.printStackTrace(); 
 
    } 
 
  } 
 
  
 
    public static void main(String[] args) { 
 
       Date now = new Date(); 
 
       long lnow = now.getTime(); 
 
       Date selDate = new Date(); 
 
       SimpleDateFormat df = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); 
 
       df.setTimeZone(TimeZone.getTimeZone("Etc/GMT-8")); 
 
       String sSel_date = df.format(selDate); 
 
       PropertyConfigurator.configure("/telstar/bin/tomcatJK/logtomcatJK.properties"); 
 
       logger.debug("------------------开始监控---------------------"); 
 
       while (true) { 
 
           try { 
 
              TomcatDetector.keepTomcatAlive(); 
 
              logger.debug("------------------检测tomcat状态---------------------"); 
 
              Thread.sleep(24000); 
 
           } catch (Exception ex) { 
 
           } 
 
       } 
 
    } 
 }