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

Tomcat之——宕机自动重启和每日定时启动tomcat在项目后期维护中会遇到这样的情况,tomcat在内存溢出的时候就出现死机的情况和遇到长时间不响应,需要人工手动关闭和重启服务,针对这样的突发情况,希望程序能自动处理问题而不需要人工关于,所以才有了目前的需求。一、设置tomcat定时启动1,首先将tomcat注册为服务,先打开tomcat的bin目录下service.bat文件,修改下面的值,这是sevvice的注册名称和显示名称,一般

大家好,又见面了,我是你们的朋友全栈君。

转载请注明出处: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:

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStream;
import java.io.InputStreamReader;
import java.net.MalformedURLException;
import java.net.URL;
import java.net.URLConnection;
import java.util.Properties;
/**
 * @describe:TomcatMonitor.java
 * 
 * @date 2017-03-06
 * @author liuyazhuang
 */
public class TomcatMonitor implements Runnable{
    
    String start=""; //系统命令 启动
    String stop=""; //系统命令 关闭
    String testHttp="";  //测试连接地址
    int testIntervalTime=1;//测试连接间隔时间,单位为秒
    int waitIntervalTime=2; //等待测试间隔时间,单位为秒
    int testTotalCount=5; //测试连接总次数
    
    Thread thread=null;
    
    public TomcatMonitor(){
        InputStream in = TomcatMonitor.class.getResourceAsStream("config.properties");
        Properties p = new Properties();
         try {
            p.load(in);
            stop=p.getProperty("stop");
            start=p.getProperty("start");
            testHttp=p.getProperty("testHttp");
            testIntervalTime=Integer.parseInt(p.getProperty("testIntervalTime"));
            waitIntervalTime=Integer.parseInt(p.getProperty("waitIntervalTime"));
            testTotalCount=Integer.parseInt(p.getProperty("testTotalCount"));           
        } catch (Exception e) {
                    e.printStackTrace();
        }
            
        System.out.println("*******************初始化成功!*******************");
         
        
        thread=new Thread(this);
        thread.start();     
    }
    
    public void run() {
        System.out.println("正在监控中...");   
        int testCount=0;
        while(true){
            testCount=0;
            testCount++;            
            boolean isrun=test();
            System.out.println("正在启动测试连接,尝试连接次数为:"+testCount+",结果为:"+(isrun==false?"失败.":"成功!"));               
            while(!isrun){
                if(testCount>=testTotalCount)break;
                try {
                    Thread.sleep(testIntervalTime*1000);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                }
                testCount++;
                System.out.println("正在启动测试连接,尝试连接次数为:"+testCount+",结果为:"+(isrun==false?"失败.":"成功!"));               
                isrun=test();
            }
            
            if(!isrun){             
                try{      
                    //关闭tomcat服务    
                    Process proc = Runtime.getRuntime().exec(stop);
                    Thread.sleep(5000);
                    //启动tomcat服务
                    System.out.println("测试连接失败,正在重启tomcat");
                    Process p=Runtime.getRuntime().exec(start); 
                    System.out.println("重启tomcat成功");
                }catch(Exception e){
                    e.printStackTrace();
                    System.out.println("重启tomcat异常,请查看先关错误信息。。。。。");
                    
                }               
            }
            
            try {
                Thread.sleep(waitIntervalTime*1000);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            
            isrun=test();
        }       
    }
    
    public boolean test(){
        
        URL url=null;       
        try {
            url = new URL(testHttp);
        } catch (MalformedURLException e) {
            e.printStackTrace();
        }
        try {
            URLConnection urlConn=url.openConnection();
            urlConn.setReadTimeout(15000);
            BufferedReader reader = new BufferedReader(new InputStreamReader( urlConn.getInputStream()));            //实例化输入流,并获取网页代码
                   String s;                                       
                   while ((s = reader.readLine()) != null) {
                      return true;   
                   }                        
        } catch (Exception e) {
          return false;
        }
        return false;
    }
    
    
    public static void main(String[] args) throws Exception{
        TomcatMonitor tm=new TomcatMonitor();
    }

}

然后是对应的配置文件config.properties:

#系统命令 启动
start=net start Tomcat7

#关闭
stop = net stop Tomcat7

#测试连接总次数
testTotalCount=3

#连接失败时,再次检测时间间隔,单位为秒
testIntervalTime=3

#连接超时时间,即多少秒tomcat没响应视为宕机,单位为秒
connectionTimeout=15

#tomcat启动时间,防止在tomcat尚未启动完成的时候,程序又去检验tomcat状态,造成尚未启动完成又重新启动,单位为秒
tomcatStartTime=600

#测试连接地址
testHttp=http://127.0.0.1:8080

#正常情况下,每次检测间隔时间,单位为秒
waitIntervalTime=30

最后是启动的start.bat:

java -cp . TomcatMonitor

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/163648.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Struts2漏洞总结

    Struts2漏洞总结Struts2漏洞总结

    2022年7月19日
    21
  • Java多维数组声明格式

    Java多维数组声明格式刷题目再次遇到了声明这种最基本形式的考题,以此记录,共勉。关于多维数组声明的形式你知道哪几种呢?首先先上一个错误的例子:这里arr9-arr11在等式右边都错误的在中括号中加了数组大小,导致报错;而arr11、arr12则是等式右边二维数组初始化时没有赋予初始大小导致报错。正确的声明形式如下:本质上arr0、arr4和arr3、arr8是一样的;而arr1-2和arr5-…

    2022年5月5日
    40
  • linux中如何查看端口占用情况「建议收藏」

    linux中如何查看端口占用情况「建议收藏」lsoflsof(listopenfiles)是一个列出当前系统打开文件的工具。lsof查看端口占用语法格式:lsof-i:端口号实例查看服务器8000端口的占用情况:#lsof-i:8000COMMANDPIDUSERFDTYPEDEVICESIZE/OFFNODENAMEnodejs26993root10uIPv4379995140t0TCP*:8000(LISTEN)可以看到8000端口已经

    2025年6月17日
    3
  • SpringBoot+jsp项目启动出现404[通俗易懂]

    SpringBoot+jsp项目启动出现404[通俗易懂]SpringBoot+jsp项目启动出现404

    2022年4月21日
    125
  • 950. 郁闷的出纳员(Splay树)「建议收藏」

    950. 郁闷的出纳员(Splay树)「建议收藏」OIER 公司是一家大型专业化软件公司,有着数以万计的员工。作为一名出纳员,我的任务之一便是统计每位员工的工资。这本来是一份不错的工作,但是令人郁闷的是,我们的老板反复无常,经常调整员工的工资。如果他心情好,就可能把每位员工的工资加上一个相同的量。反之,如果心情不好,就可能把他们的工资扣除一个相同的量。我真不知道除了调工资他还做什么其它事情。工资的频繁调整很让员工反感,尤其是集体扣除工资的时候,一旦某位员工发现自己的工资已经低于了合同规定的工资下界,他就会立刻气愤地离开公司,并且再也不会回来了。

    2022年8月9日
    6
  • python 获取当前日期 星期[通俗易懂]

    python 获取当前日期 星期

    2022年1月24日
    54

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号