Java操作另一个Java程序使其重启的简单实现
大概思路:
写两个程序,一个负责重启的程序,一个是待重启的程序,在这里为了区分我们假设负责重启的那个程序叫A,待重启的程序叫B,他们都是线程,还要搭配数据库,他是两个程序的桥梁,通过设置信号量进行判断程序状态(不妨设置信号量为Flag),我是这么设置的,0:表示程序正在运行中,1:表示程序需要重启,正准备做关闭自己的操作(只针对待重启的程序B),2:表示B程序已经把自己给关闭了,需要A程序把B程序启动。
实现步骤:
A程序:写一个线程进行读信号量Flag,当Flag为2的时候就把B程序启动
B程序:写一个线程进行读信号量Flag,当Flag为1的时候就把自己给关闭(javaSystem.exit(0);)
数据库:需要一个表存Flag的值,创建表restart,并新建一个字段Flag,int(4)noNull
实现细节:
A程序:
packagecom.app; importjava.io.IOException; importjava.sql.ResultSet; importjava.sql.SQLException; importdatabasetool.DBtool; publicclassReStartimplementsRunnable{ intstatus=0; publicvoidrun(){ DBtoolcon=newDBtool(); ResultSetrs=null; Stringselect="select*fromrestart"; Stringrestar="updaterestartsetstatus='0'";//准备启动程序,设置Status为0,表示已启动 try{ intresult=con.executeUpdate(restar); System.out.println("初始化,并将status状态设置为0,表示程序正常被启动了!"); }catch(SQLExceptione){ e.printStackTrace(); } while(true){ while(true){ if(status==2){//2:表示关闭的程序等待重启 System.out.println("status状态为2,表示需要重新启动数采程序!"); try{ intresult=con.executeUpdate(restar); System.out.println("程序马上就被启动,并将status状态设置为0,表示程序正常运行!"); }catch(SQLExceptione){ e.printStackTrace(); } Stringcmd="cmd/cstartE:\\Bats\\MainThread.bat";//pass try{ Processps=Runtime.getRuntime().exec(cmd); ps.waitFor(); }catch(IOExceptionioe){ ioe.printStackTrace(); }catch(InterruptedExceptione){ e.printStackTrace(); } } try{ rs=con.executeQuery(select); while(rs.next()){ status=rs.getInt("status"); System.out.println("检测当前状态status:"+status); } }catch(SQLExceptione){ e.printStackTrace(); } try{ Thread.sleep(5000); }catch(InterruptedExceptione){ e.printStackTrace(); } } } } publicstaticvoidmain(String[]args){ ReStartres=newReStart(); res.run(); } }
B程序:
packagedatacollect; importjava.sql.ResultSet; importjava.sql.SQLException; importdatabasetool.DBtool; publicclassExitMainimplementsRunnable{ @Override publicvoidrun(){ DBtooldbtool=newDBtool(); intstatus=0;//0:表示不需要重启 ResultSetrs=null; Stringselect="select*fromrestart"; Stringrestar="updaterestartsetstatus='2'";//关闭了程序,等待重启 //写日志相关内容 while(true){ try{ rs=dbtool.executeQuery(select); while(rs.next()){ status=rs.getInt("status"); } }catch(SQLExceptione){ e.printStackTrace(); } if(status==1){//1:表示等待关闭程序 System.out.println("status状态为1,表示需要关闭当前程序!"); try{ intresult=dbtool.executeUpdate(restar); System.out.println("程序马上就被关闭,并将status状态设置为2,表示程序关闭了,需要重启!"); }catch(SQLExceptione){ e.printStackTrace(); } System.exit(0); } try{ Thread.sleep(5000); }catch(InterruptedExceptione){ //TODOAuto-generatedcatchblock e.printStackTrace(); } } } publicstaticvoidmain(String[]args){ ExitMainextm=newExitMain(); extm.run(); } }
数据库读取工具类:
packagedatabasetool; importjava.sql.Connection; importjava.sql.DriverManager; importjava.sql.ResultSet; importjava.sql.SQLException; importjava.sql.Statement; publicclassDBtool{ privateConnectionconnection=null; publicStatementstatement=null; privateResultSetresult=null; publicDBtool(){ try{ Class.forName("com.microsoft.sqlserver.jdbc.SQLServerDriver"); Stringurl="jdbc:sqlserver://localhost:1433;databaseName=tianjincollect;user=sa;password=123456"; connection=DriverManager.getConnection(url); statement=connection.createStatement(); }catch(SQLExceptionex){ System.out.println(ex.getMessage()); }catch(ClassNotFoundExceptionex){ System.out.println(ex.getMessage()); } } publicResultSetexecuteQuery(Stringsql)throwsSQLException{ try{ result=statement.executeQuery(sql); }catch(SQLExceptionse){ System.out.println("ERROR:"+se.getMessage()); } returnresult; } publicintexecuteUpdate(Stringsql)throwsSQLException{ intupdatenum=0; try{ updatenum=statement.executeUpdate(sql); returnupdatenum; }catch(SQLExceptionse){ System.out.println("ERROR:"+se.getMessage()); } returnupdatenum; } publicvoidfree()throwsSQLException{ try{ if(result!=null) result.close(); if(statement!=null) statement.close(); if(connection!=null) connection.close(); }catch(SQLExceptionse){ System.out.println("ERROR:"+se.getMessage()); } } publicstaticvoidmain(String[]args){ DBtoolcon=newDBtool(); ResultSetrs=null; Stringsql="select*fromrestart"; try{ rs=con.executeQuery(sql); while(rs.next()){ intstatus=rs.getInt("status"); System.out.println(status); } }catch(SQLExceptione){ e.printStackTrace(); } sql="updaterestartsetstatus='1'"; try{ intresult=con.executeUpdate(sql); }catch(SQLExceptione){ e.printStackTrace(); } } }
以上这篇Java操作另一个Java程序使其重启的简单实现就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持毛票票。