- 浏览: 37607 次
- 性别:
- 来自: 深圳
最新评论
原理很简单。 在机器上做一个测试的文件。如果我们的程序能够读取到这个文件,则证明运行正常,可简单实现Tomcat HA.
另一种方式:监控日志
由于tomcat部署的应用,在客户使用的过程中,每过五六天总会吊死成僵尸进程,查看日志为无效的变元,搜遍网络,尝试了很多办法也没有解决此问题。同时不能更换web容器,因为会增加成本,只好用java写了个监控程序,目前正在测试中
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) { } } } }
发表评论
-
MD5加密文件
2013-08-19 17:36 655package com; import java.io.Fi ... -
java get提交
2012-03-01 16:09 903import java.io.IOException; ... -
图片写入文件夹
2011-11-10 08:57 927private static void copy(File ... -
有关日期工具类
2011-03-31 14:01 758/* 有关日期工具类(extends TimeUtil) ... -
FusionChartsFree应用 参数设置
2011-03-30 15:40 1281<chart caption='各地市对比图' xAxi ... -
DES可逆加密算法
2011-03-28 13:54 7054/** *@Company: *@Copyri ... -
Exception loading sessions from persistent storage
2011-03-22 14:17 750Exception loading sessions from ... -
读取资源文件
2011-03-18 15:29 710package com.lcconsole.util; ...
相关推荐
根据提供的信息,我们可以总结出以下知识点: ...通过以上知识点的学习,可以了解到如何通过Java程序实现对Tomcat服务器状态的自动检测与重启,这对于保障基于Tomcat的应用系统持续可用具有重要意义。
当检测到Tomcat服务假死或异常时,自动重启过程可以由同一脚本触发。在Windows环境下,可以使用Taskkill命令结束Tomcat进程,然后使用启动命令(如`startup.bat`)重新启动Tomcat。确保脚本具有适当的权限,以便能够...
本文将深入探讨如何使用提供的压缩包文件来实现对Tomcat运行状态的监控,并在出现假死或异常停止时进行自动重启。这个解决方案主要依赖于一个批处理脚本"监控tomcat.bat",以及可能需要的辅助工具如"curl.exe"。 ...
Shell脚本定时监控tomcat,服务挂掉自动重启
下面,我们将详细介绍如何使用 Java 代码来启动 Tomcat 服务器,并实现远程控制 Tomcat。 标题: Java 代码启动 Tomcat 描述: Java 实现 Tomcat 的自启动和关闭,可实现远程控制 Tomcat 标签: Java Tomcat ...
监控Tomcat的状态和自动重启是系统管理员日常维护工作的重要部分,确保服务的稳定性和高可用性。本文将深入探讨如何有效地对Tomcat进行监控以及设置自动重启策略。 首先,我们来了解Tomcat的监控。监控主要关注以下...
为了保证服务的连续性和稳定性,我们需要编写一个批处理脚本来监控Tomcat的状态,并在检测到异常时自动重启Tomcat。 "listener.bat" 文件很可能是这个自动重启脚本的核心部分。批处理脚本通常由一系列命令组成,...
【标题】"TOMCAT自动...自动检测和重启TOMCAT的功能能有效减少服务中断,提高系统的可用性和稳定性。通过合理配置,我们可以确保即使在TOMCAT意外停机的情况下,也能迅速恢复服务,从而提升用户满意度和业务连续性。
总的来说,自动重启Tomcat脚本是保障服务持续运行的有效手段,通过定期检查和自动恢复,减少了手动干预的需求,提高了系统的稳定性。通过理解和定制这些脚本,可以根据具体环境优化自动重启策略,以实现最佳的服务器...
在网上找了好多关于Nsis打包JavaWeb和tomcat的方法,都没有能让tomcat服务自动重启的,便自己研究编写了一个方法。供大家参考! 1、实现程序一键安装 2、卸载 3、安装时验证密码 4、应用系统快捷方式启动、注册...
2. **Tomcat重启脚本**:`tomcatst.bat`文件很可能是用于启动或停止Tomcat服务的批处理脚本。在Windows环境下,这个脚本可能包含了诸如`startup.bat`和`shutdown.bat`的调用,这些是Tomcat自带的命令行工具,用于...
这种守护过程通常由一个额外的程序或脚本实现,它监控Tomcat的运行状态,并在检测到服务异常时执行重启操作。 描述中提到的“自动重启已挂掉的tomcat服务器,省去人工人力,保证服务器的正常运行”,意味着通过自动...
tomcat宕机重启脚本,比较简单的一种设置
在部分内容中,我们可以看到使用 Java 程序来监听 Tomcat 服务器的状态,并在 Tomcat 无响应时自动重启 Tomcat 的实现思路。 监听 Tomcat 服务器状态 在 Java 程序中,我们使用定时访问服务器端固定的 JSP 页面...
jsp解决文件上传后重启Tomcat时文件自动删除问题 本文主要介绍了jsp解决文件上传后重启Tomcat时文件自动删除问题,包括问题分析和详细解决方法。该问题是指在jsp项目中上传文件后,重启Tomcat服务器或清理缓存时,...
Linux 系统 Tomcat 重启脚本判断日志超过一定大小自动重启,是指在 Linux 操作系统中使用 shell 脚本来监控 Tomcat 服务器的日志文件大小,当日志文件超过一定大小时,自动重启 Tomcat 服务器,以确保服务的稳定运行...
为了提高系统的可靠性和稳定性,开发了一个Java实现的监控程序,它的主要功能是监听服务程序的状态,如果检测到程序意外终止或挂掉,它会自动重启该程序,并且向开发人员发送短信通知,以便快速了解问题并采取相应的...
提高开发效率之tomcat免重启(随意更改java代码)提高开发效率之tomcat免重启(随意更改java代码)提高开发效率之tomcat免重启(随意更改java代码)提高开发效率之tomcat免重启(随意更改java代码)
首先,在server.xml文件中添加Context元素,然后使用ssh连接到Tomcat服务器,并重启Tomcat服务。 四、JVM内存分配机制 JVM将内存分为不同的区,包括Heap space、PermGen space等。Heap space用于存放对象,GC会...