java 反射执行shell,Java调用运行shell脚本

做一下记录 ` private static Logger logger = Logger.getLogger(JavaRunShellService.class); //基本路径 private static final String basePath = "/usr/local/java-run/logs/"; //记录Shell执行状况的日志文件的位置(绝对路径) private static final String logFile = basePath + "executeShell.log";

public int executeShell(String shellCommand) throws IOException {

logger.info("============转入shell方法==============");

int success = 0;

StringBuffer stringBuffer = new StringBuffer();

BufferedReader bufferedReader = null;

//格式化日期时间,记录日志时使用

DateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:SS");

try {

stringBuffer.append(dateFormat.format(new Date())).append("准备执行Shell命令 :").append(shellCommand).append("\r\n");

Process pid = null;

String[] cmd = {"/bin/sh", "-c", shellCommand};

//执行Shell命令

pid = Runtime.getRuntime().exec(cmd);

if (pid != null) {

stringBuffer.append("进程号:").append(pid.toString()).append("\r\n");

//bufferedReader用于读取Shell的输出内容

bufferedReader = new BufferedReader(new InputStreamReader(pid.getInputStream()));

} else {

stringBuffer.append("没有pid\r\n");

}

stringBuffer.append(dateFormat.format(new Date())).append("Shell命令执行完毕\r\n执行结果为:\r\n");

String line = null;

//读取Shell的输出内容,并添加到stringBuffer中

while (bufferedReader != null && (line = bufferedReader.readLine()) != null) {

stringBuffer.append(line).append("\r\n");

}

} catch (Exception ex) {

//ex.printStackTrace();

stringBuffer.append("执行Shell命令时发生异常:\r\n").append(ex.getMessage()).append("\r\n");

} finally {

if (bufferedReader != null) {

OutputStreamWriter outputStreamWriter = null;

try {

bufferedReader.close();

//将Shell的执行情况输出到日志文件中

OutputStream outputStream = new FileOutputStream(logFile);

outputStreamWriter = new OutputStreamWriter(outputStream, "UTF-8");

outputStreamWriter.write(stringBuffer.toString());

} catch (Exception e) {

e.printStackTrace();

} finally {

outputStreamWriter.close();

}

}

success = 1;

}

return success;

}

`

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值