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;
}

`

转载于:https://my.oschina.net/u/1393778/blog/804343

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值