java远程调用shell脚本

1.maven引入jar包

<dependency>
    <groupId>ch.ethz.ganymed</groupId>
    <artifactId>ganymed-ssh2</artifactId>
    <version>build210</version>
</dependency>

2.写java类

/**
 * Created by admin on 2019/1/10.
 */

import ch.ethz.ssh2.ChannelCondition;
import ch.ethz.ssh2.Connection;
import ch.ethz.ssh2.Session;
import ch.ethz.ssh2.StreamGobbler;
import org.apache.poi.util.IOUtils;

import java.io.IOException;
import java.io.InputStream;
import java.nio.charset.Charset;

/**
 * 执行shell脚本的方法
 */
public class UtilExcuteSql {

	private Connection conn;
	private String     ip; //ip
	private int        prot; //端口
	private String     osUsername; //服务器的用户名
	private String     password;   //服务器的密码
	private String charset = Charset.defaultCharset().toString();
	private static final int TIME_OUT = 1000 * 5 * 60;

	public static void main(String [] args){
		try{
			UtilExcuteSql executor = new UtilExcuteSql("主机地址",端口,"用户名", "密码");
			executor.exec("sh /tmp/liuzhiling.sh");
		}catch (Exception e){
			e.printStackTrace();
		}
	}

	/**
	 * 登录
	 * @return
	 * @throws IOException
	 */
	private boolean login() throws IOException {
		conn = new Connection(ip,prot);
		conn.connect();
		return conn.authenticateWithPassword(osUsername, password);

	}

	/**
	 * 执行
	 * @param cmds
	 * @return
	 * @throws Exception
	 */
	public int exec(String cmds) throws Exception {
		InputStream stdOut = null;
		InputStream stdErr = null;
		String outStr = "";
		String outErr = "";
		int ret = -1;
		try {
			if (login()) {
				Session session = conn.openSession();
				session.execCommand(cmds);
				stdOut = new StreamGobbler(session.getStdout());
				outStr = processStream(stdOut, charset);
				stdErr = new StreamGobbler(session.getStderr());
				outErr = processStream(stdErr, charset);
				session.waitForCondition(ChannelCondition.EXIT_STATUS, TIME_OUT);
				System.out.println("outStr=" + outStr);
				System.out.println("outErr=" + outErr);
				ret = session.getExitStatus();
			} else {
				throw new Exception("登录远程机器失败" + ip); // 自定义异常类 实现略
			}
		} finally {
			if (conn != null) {
				conn.close();
			}
			IOUtils.closeQuietly(stdOut);
			IOUtils.closeQuietly(stdErr);
		}
		return ret;

	}

	private String processStream(InputStream in, String charset) throws Exception {
		byte[] buf = new byte[1024];
		StringBuilder sb = new StringBuilder();
		while (in.read(buf) != -1) {
			sb.append(new String(buf, charset));
		}
		return sb.toString();
	}

	public UtilExcuteSql(String ip,int prot,String usr, String pasword) {
		this.ip = ip;
		this.prot=prot;
		this.osUsername = usr;
		this.password = pasword;
	}



}
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值