使用JSch和Java捕获服务器命令输出

时间:2016-01-14 21:11:11

标签: java ssh stdout jsch

我正在使用JSch来ssh到多个服务器并运行一些命令。我的输出文件捕获了一切。但我正在寻找一种只捕获服务器响应的方法。

代码:

try (OutputStream log = new BufferedOutputStream( new FileOutputStream("OUTPUT_FILE"))) {
    JSch jsch = new JSch();

    for (String host : jssh.listOfhost()) {
        Session session = jsch.getSession(user, host, 22);
        session.setPassword(password);
        session.setConfig(getProperties());
        session.connect(10 * 1000);

        Channel channel = session.openChannel("shell");
        channel.setOutputStream(log, true);

        try (PipedInputStream commandSource = new PipedInputStream();
             OutputStream commandSink = new PipedOutputStream(commandSource)) {

            CommandSender sender = new CommandSender(commandSink);
            Thread sendThread = new Thread(sender);
            sendThread.start();

            channel.setInputStream(commandSource);
            channel.connect(15 * 1000);

            sendThread.join();
            if (sender.exception != null) {
                throw sender.exception;
            }
        }

        channel.disconnect();
        session.disconnect();
    }
}

当前输出:

Last login: Thu Jan 14 15:06:17 2016 from 192.168.1.4
mypc:~ user$ 
mypc:~ user$ hostname
mypc
mypc:~ user$ df -l | grep disk0s3 |tr -s [:blank:]|cut -d ' ' -f 7
19098537

但我只想输出以下内容

mypc 19098537

以下两个命令的结果

hostname
df -l | grep disk0s3 |tr -s [:blank:]|cut -d ' ' -f 7

1 个答案:

答案 0 :(得分:1)

使用exec频道,而不是shell频道。 exec通道用于执行命令。 shell频道旨在实现交互式会话。这就是为什么你得到所有提示等等。您无法在exec频道中获取这些内容。

请参阅official JSCh example for using exec channel

如果您需要阅读stdout和stderr,请参阅我对How to read JSch command output?的回答