Java操作另一个Java程序使其重启的简单实现

 更新时间:2017年03月09日 09:05:28   投稿:jingxian  
下面小编就为大家带来一篇Java操作另一个Java程序使其重启的简单实现。小编觉得挺不错的,现在就分享给大家,也给大家做个参考。一起跟随小编过来看看吧

大概思路:

写两个程序,一个负责重启的程序,一个是待重启的程序,在这里为了区分我们假设负责重启的那个程序叫A,待重启的程序叫B,他们都是线程,还要搭配数据库,他是两个程序的桥梁,通过设置信号量进行判断程序状态(不妨设置信号量为Flag),我是这么设置的,0:表示程序正在运行中,1:表示程序需要重启,正准备做关闭自己的操作(只针对待重启的程序B),2:表示B程序已经把自己给关闭了,需要A程序把B程序启动。

实现步骤:

A程序:写一个线程进行读信号量Flag,当Flag为2的时候就把B程序启动

B程序:写一个线程进行读信号量Flag,当Flag为1的时候就把自己给关闭(java System.exit(0);)

数据库:需要一个表存Flag的值,创建表restart,并新建一个字段Flag,int(4)noNull

实现细节:

A 程序:

package com.app;

import java.io.IOException;
import java.sql.ResultSet;
import java.sql.SQLException;

import databasetool.DBtool;

public class ReStart implements Runnable {
  int status = 0;

  public void run() {
    DBtool con = new DBtool();
    ResultSet rs = null;
    String select = "select * from restart";
    String restar = "update restart set status = '0'";// 准备启动程序,设置Status为0,表示已启动
    try {
      int result = con.executeUpdate(restar);
      System.out.println("初始化,并将status状态设置为0,表示程序正常被启动了!");
    } catch (SQLException e) {
      e.printStackTrace();
    }
    while (true) {
      while (true) {
        if (status == 2) {// 2:表示关闭的程序等待重启
          System.out.println("status状态为2,表示需要重新启动数采程序!");
          try {
            int result = con.executeUpdate(restar);
            System.out.println("程序马上就被启动,并将status状态设置为0,表示程序正常运行!");
          } catch (SQLException e) {
            e.printStackTrace();
          }
          String cmd = "cmd /c start E:\\Bats\\MainThread.bat";// pass
          try {
            Process ps = Runtime.getRuntime().exec(cmd);
            ps.waitFor();
          } catch (IOException ioe) {
            ioe.printStackTrace();
          } catch (InterruptedException e) {
            e.printStackTrace();
          }
        }
        try {
          rs = con.executeQuery(select);
          while (rs.next()) {
            status = rs.getInt("status");
            System.out.println("检测当前状态status:"+status);
          }
        } catch (SQLException e) {
          e.printStackTrace();
        }
        try {
          Thread.sleep(5000);
        } catch (InterruptedException e) {
          e.printStackTrace();
        }
      }
    }
  }

  public static void main(String[] args) {
    ReStart res = new ReStart();
    res.run();
  }

}

B程序:

package datacollect;

import java.sql.ResultSet;
import java.sql.SQLException;

import databasetool.DBtool;

public class ExitMain implements Runnable {

  @Override
  public void run() {
    DBtool dbtool = new DBtool();
    int status = 0;// 0:表示不需要重启
    ResultSet rs = null;
    String select = "select * from restart";
    String restar = "update restart set status = '2'";// 关闭了程序,等待重启

    // 写日志相关内容

    while (true) {

      try {
        rs = dbtool.executeQuery(select);
        while (rs.next()) {
          status = rs.getInt("status");
        }
      } catch (SQLException e) {
        e.printStackTrace();
      }
      if (status == 1) {// 1:表示等待关闭程序
        System.out.println("status状态为1,表示需要关闭当前程序!");
        try {
          int result = dbtool.executeUpdate(restar);
          System.out.println("程序马上就被关闭,并将status状态设置为2,表示程序关闭了,需要重启!");
        } catch (SQLException e) {
          e.printStackTrace();
        }
        System.exit(0);
      }
      try {
        Thread.sleep(5000);
      } catch (InterruptedException e) {
        // TODO Auto-generated catch block
        e.printStackTrace();
      }
    }
  }

  public static void main(String[] args) {
    ExitMain extm = new ExitMain();
    extm.run();
  }

}

数据库读取工具类:

package databasetool;

import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

public class DBtool {

  private Connection connection = null;
  public Statement statement = null;
  private ResultSet result = null;


  public DBtool() {
    try {
        Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver");
        String url = "jdbc:sqlserver://localhost:1433;databaseName=tianjincollect;user=sa;password=123456";
        connection = DriverManager.getConnection(url);
        statement = connection.createStatement();      
      } catch (SQLException ex) {
        System.out.println(ex.getMessage());
      } catch (ClassNotFoundException ex) {
        System.out.println(ex.getMessage());
      }
  }

  public ResultSet executeQuery(String sql) throws SQLException {
    try {
      result = statement.executeQuery(sql);
    } catch (SQLException se) {
      System.out.println("ERROR:" + se.getMessage());     
    }
    return result;
  }

  public int executeUpdate(String sql) throws SQLException {
    int updatenum = 0;
    try {
      updatenum = statement.executeUpdate(sql);
      return updatenum;
    } catch (SQLException se) {
      System.out.println("ERROR:" + se.getMessage()); 
    }
    return updatenum;
  }

  public void free() throws SQLException {
    try {
      if (result != null)
        result.close();
      if (statement != null)
        statement.close();
      if (connection != null)
        connection.close();
    } catch (SQLException se) {
      System.out.println("ERROR:" + se.getMessage());
    }
  }
  public static void main(String[] args) {
    DBtool con = new DBtool();
    ResultSet rs = null;
    String sql = "select * from restart";
    try {
      rs = con.executeQuery(sql);
      while(rs.next()){
        int status = rs.getInt("status");
        System.out.println(status);
      }
    } catch (SQLException e) {
      e.printStackTrace();
    }
    sql = "update restart set status = '1'";
    try {
      int result = con.executeUpdate(sql);
    } catch (SQLException e) {
      e.printStackTrace();
    }
  }
}

以上这篇Java操作另一个Java程序使其重启的简单实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持脚本之家。

相关文章

  • Java并发编程系列之LockSupport的用法

    Java并发编程系列之LockSupport的用法

    这篇文章主要为大家介绍了Java LockSupport的用法,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助,希望能够给你带来帮助
    2021-11-11
  • IDEA的部署设置改为war exploded运行项目出错问题

    IDEA的部署设置改为war exploded运行项目出错问题

    在使用IDEA配置warexploded部署时,可能会遇到路径问题或404错误,解决方法是进入Deployment设置,删除Application content中的/marry_war_exploded,使其为空,然后重新运行项目即可,这是一种有效的解决策略,希望能帮助到遇到同样问题的开发者
    2024-10-10
  • Java线程(Thread)四种停止方式代码实例

    Java线程(Thread)四种停止方式代码实例

    这篇文章主要介绍了Java线程(Thread)四种停止方式代码实例,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以参考下
    2020-03-03
  • Spring boot Rabbitmq消息防丢失实践

    Spring boot Rabbitmq消息防丢失实践

    这篇文章主要介绍了Spring boot Rabbitmq消息防丢失实践,文章围绕主题展开详细的内容介绍,具有一定的参考价值,需要的小伙伴可以参考一下
    2022-09-09
  • java 图片与base64相互转化的示例

    java 图片与base64相互转化的示例

    这篇文章主要介绍了java 图片与base64相互转化的示例,帮助大家更好的理解和使用Java,感兴趣的朋友可以了解下
    2020-10-10
  • 一篇文章带你了解mybatis的动态SQL

    一篇文章带你了解mybatis的动态SQL

    这篇文章主要为大家介绍了mybatis的动态SQL ,具有一定的参考价值,感兴趣的小伙伴们可以参考一下,希望能够给你带来帮助
    2022-01-01
  • RabbitMQ 延迟队列实现订单支付结果异步阶梯性通知(实例代码)

    RabbitMQ 延迟队列实现订单支付结果异步阶梯性通知(实例代码)

    这篇文章主要介绍了RabbitMQ 延迟队列实现订单支付结果异步阶梯性通知,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下
    2022-02-02
  • springboot集成nacos无法动态获取nacos配置的问题

    springboot集成nacos无法动态获取nacos配置的问题

    这篇文章主要介绍了springboot集成nacos无法动态获取nacos配置的问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
    2023-09-09
  • Java实现电影院订票系统代码

    Java实现电影院订票系统代码

    这篇文章主要介绍了Java实现电影院订票系统代码,代码实现了界面类登录注册类,用户类等,具有一定参考价值,需要的朋友可以参考下。
    2017-11-11
  • Spring Cloud Feign实现文件上传下载的示例代码

    Spring Cloud Feign实现文件上传下载的示例代码

    Feign框架对于文件上传消息体格式并没有做原生支持,需要集成模块feign-form来实现,本文就详细的介绍一下如何使用,感兴趣的可以了解一下
    2022-02-02

最新评论