利用Ganymed SSH-2 for Java 连接到远程服务器,然后执行shell命令;
首先我们再在之前CommandRunner类中再添加一个执行shell命令的方法,具体如下所示:
public static String execShellScript(String host, String username, String password, String cmd, int port) throws IOException { if (logger.isInfoEnabled()) { logger.info("running SSH cmd [" + cmd + "]"); } Connection conn = null; Session sess = null; InputStream stdout = null; BufferedReader br = null; StringBuffer buffer = new StringBuffer("exec result:"); buffer.append(System.getProperty("line.separator"));// 换行 try { conn = getOpenedConnection(host, username, password, port); sess = conn.openSession(); sess.execCommand(cmd); stdout = new StreamGobbler(sess.getStdout()); br = new BufferedReader(new InputStreamReader(stdout)); while (true) { // attention: do not comment this block, or you will hit // NullPointerException // when you are trying to read exit status String line = br.readLine(); if (line == null) break; buffer.append(line); buffer.append(System.getProperty("line.separator"));// 换行 if (logger.isInfoEnabled()) { logger.info(line); } } } finally { sess.close(); conn.close(); } return buffer.toString(); }
测试代码:
public static void main(String[] args) { String cmd = "uname -a"; try { String info = CommandRunner.execShellScript("172.16.18.141", "root", "123456",cmd,22); System.out.println("info is:"+info); } catch (IOException e) { e.printStackTrace(); } }
log4j:WARN No appenders could be found for logger (com.ssh2.shell.ganymed.CommandRunner).
log4j:WARN Please initialize the log4j system properly.
log4j:WARN See http://logging.apache.org/log4j/1.2/faq.html#noconfig for more info.
info is:exec result:
Linux localhost.localdomain 2.6.32-220.el6.x86_64 #1 SMP Wed Nov 9 08:03:13 EST 2011 x86_64 x86_64 x86_64 GNU/Linux
至此,连接远程服务器执行shell命令简单方法就实现了。