Tomcat之——宕机自动重启和每日定时启动tomcat

转载请注明出处:http://blog.csdn.net/l1028386804/article/details/60587663

在项目后期维护中会遇到这样的情况,tomcat在内存溢出的时候就出现死机的情况和遇到长时间不响应,需要人工手动关闭和重启服务,针对这样的突发情况,希望程序能自动处理问题而不需要人工关于,所以才有了目前的需求。

一、设置tomcat定时启动
1,首先将tomcat注册为服务,先打开tomcat的bin目录下service.bat文件,修改下面的值,这是sevvice的注册名称和显示名称,一般可使用默认值。
set SERVICE_NAME=Tomcat7 set PR_DISPLAYNAME=Apache Tomcat
【然后修改jvm大小,搜索到--JvmMs 128 --JvmMx 256 进行修改,因为做成服务启动,启动的时候就不会用到 catalina.bat,也就不会读取里面的jvm设置了。】(可选,可以不设置)
然后运行cmd命令窗口,cd 到tomcat的bin目录下,运行下面的命令 service.bat install 运行成功过后,会提示服务已经安装成功。
2,制作重启脚本restart.bat,文件内容如下 net stop Tomcat7 net start Tomcat7
3,利用控制面板里面的“任务计划”设置第2步的脚本运行时间计划
4,如果想删除服务,也很简单,先把服务停掉,然后在cmd窗口运行下面的命令即可,后面那个Tomcat7是服务名。 sc delete Tomcat7
需要注意的是,需要先把服务停掉,才能一次删除成功,或者删除之后再停止服务,就会发现服务已经删除成功了。
二、监听tomcat
只要运行start.bat即可,相关配置在config.properties文件中,默认即可, 如果服务名不对应就修改关闭和启动命令的服务名即可:net start 【Tomcat7】括号中服务名,然后运行start.bat
下面是具体的监听代码:
首先是监听类TomcatMonitor .Java:

[java]view plain copy

  1. import java.io.BufferedReader;
  2. import java.io.IOException;
  3. import java.io.InputStream;
  4. import java.io.InputStreamReader;
  5. import java.net.MalformedURLException;
  6. import java.net.URL;
  7. import java.net.URLConnection;
  8. import java.util.Properties;
  9. /**
  10. * @describe:TomcatMonitor.java
  11. *
  12. * @date 2017-03-06
  13. * @author liuyazhuang
  14. */
  15. public class TomcatMonitor implements Runnable{
  16. String start=""; //系统命令 启动
  17. String stop=""; //系统命令 关闭
  18. String testHttp=""; //测试连接地址
  19. int testIntervalTime=1; //测试连接间隔时间,单位为秒
  20. int waitIntervalTime=2; //等待测试间隔时间,单位为秒
  21. int testTotalCount=5; //测试连接总次数
  22. Thread thread=null;
  23. public TomcatMonitor(){
  24. InputStream in = TomcatMonitor.class.getResourceAsStream("config.properties");
  25. Properties p = new Properties();
  26. try {
  27. p.load(in);
  28. stop=p.getProperty("stop");
  29. start=p.getProperty("start");
  30. testHttp=p.getProperty("testHttp");
  31. testIntervalTime=Integer.parseInt(p.getProperty("testIntervalTime"));
  32. waitIntervalTime=Integer.parseInt(p.getProperty("waitIntervalTime"));
  33. testTotalCount=Integer.parseInt(p.getProperty("testTotalCount"));
  34. } catch (Exception e) {
  35. e.printStackTrace();
  36. }
  37. System.out.println("*******************初始化成功!*******************");
  38. thread=new Thread(this);
  39. thread.start();
  40. }
  41. public void run() {
  42. System.out.println("正在监控中...");
  43. int testCount=0;
  44. while(true){
  45. testCount=0;
  46. testCount++;
  47. boolean isrun=test();
  48. System.out.println("正在启动测试连接,尝试连接次数为:"+testCount+",结果为:"+(isrun==false?"失败.":"成功!"));
  49. while(!isrun){
  50. if(testCount>=testTotalCount)break;
  51. try {
  52. Thread.sleep(testIntervalTime*1000);
  53. } catch (InterruptedException e) {
  54. e.printStackTrace();
  55. }
  56. testCount++;
  57. System.out.println("正在启动测试连接,尝试连接次数为:"+testCount+",结果为:"+(isrun==false?"失败.":"成功!"));
  58. isrun=test();
  59. }
  60. if(!isrun){
  61. try{
  62. //关闭tomcat服务
  63. Process proc = Runtime.getRuntime().exec(stop);
  64. Thread.sleep(5000);
  65. //启动tomcat服务
  66. System.out.println("测试连接失败,正在重启tomcat");
  67. Process p=Runtime.getRuntime().exec(start);
  68. System.out.println("重启tomcat成功");
  69. }catch(Exception e){
  70. e.printStackTrace();
  71. System.out.println("重启tomcat异常,请查看先关错误信息。。。。。");
  72. }
  73. }
  74. try {
  75. Thread.sleep(waitIntervalTime*1000);
  76. } catch (InterruptedException e) {
  77. e.printStackTrace();
  78. }
  79. isrun=test();
  80. }
  81. }
  82. public boolean test(){
  83. URL url=null;
  84. try {
  85. url = new URL(testHttp);
  86. } catch (MalformedURLException e) {
  87. e.printStackTrace();
  88. }
  89. try {
  90. URLConnection urlConn=url.openConnection();
  91. urlConn.setReadTimeout(15000);
  92. BufferedReader reader = new BufferedReader(new InputStreamReader( urlConn.getInputStream())); //实例化输入流,并获取网页代码
  93. String s;
  94. while ((s = reader.readLine()) != null) {
  95. return true;
  96. }
  97. } catch (Exception e) {
  98. return false;
  99. }
  100. return false;
  101. }
  102. public static void main(String[] args) throws Exception{
  103. TomcatMonitor tm=new TomcatMonitor();
  104. }
  105. }
然后是对应的配置文件config.properties:
【Tomcat之——宕机自动重启和每日定时启动tomcat】
[plain]view plain copy
  1. #系统命令 启动
  2. start=net start Tomcat7
  3. #关闭
  4. stop = net stop Tomcat7
  5. #测试连接总次数
  6. testTotalCount=3
  7. #连接失败时,再次检测时间间隔,单位为秒
  8. testIntervalTime=3
  9. #连接超时时间,即多少秒tomcat没响应视为宕机,单位为秒
  10. connectionTimeout=15
  11. #tomcat启动时间,防止在tomcat尚未启动完成的时候,程序又去检验tomcat状态,造成尚未启动完成又重新启动,单位为秒
  12. tomcatStartTime=600
  13. #测试连接地址
  14. testHttp=http://127.0.0.1:8080
  15. #正常情况下,每次检测间隔时间,单位为秒
  16. waitIntervalTime=30
最后是启动的start.bat:
[java]view plain copy
  1. java -cp . TomcatMonitor

    推荐阅读