"tail -f" JSch 连接关闭后进程不会退出
"tail -f" process will not exit after JSch connection closed
我使用 JSch 在远程计算机中跟踪文件。但是我发现程序退出后,
"tail -f" 进程仍在远程计算机中。
如果我删除“-f”参数,一切正常。
我试过使用 "sendSignal()",但没用。似乎该功能未由 OpenSSH 实现。
这是测试代码。
public static void main(String[] args) throws Exception {
String usr = args[0];
String host = args[1];
String password = args[2];
JSch jsch = new JSch();
Session session = jsch.getSession(usr, host);
String pwd = password;
session.setPassword(pwd);
Hashtable<String, String> config = new Hashtable<String, String>();
config.put("StrictHostKeyChecking", "no");
session.setConfig(config);
session.connect(15000);
session.setServerAliveInterval(15000);
ChannelExec m_channelExec = (ChannelExec) session.openChannel("exec");
String cmd = "tail -f /var/log/messages";
m_channelExec.setCommand(cmd);
InputStream m_in = m_channelExec.getInputStream();
m_channelExec.connect();
BufferedReader m_bufferedReader = new BufferedReader(new InputStreamReader(m_in));
int i = 0;
while (++i < 10) {
if (m_bufferedReader.ready()) {
String line = m_bufferedReader.readLine();
System.out.println(line);
}
Thread.sleep(1000);
}
m_bufferedReader.close();
m_channelExec.sendSignal("SIGINT");
m_channelExec.disconnect();
session.disconnect();
System.out.println("exit");
}
有解决这个问题的方法吗?
execCommand 不 将控制 tty 分配给通道,因此 tail 实际上是在写入管道。它会继续,直到有更多数据发送给它(它会得到一个 SIGPIPE)。
最简单的解决方案是分配一个 tty - 使用:
m_channelExec.setPty(true);
在 m_channelExec.connect();
之前的行
这应该会给你想要的行为。
我使用 JSch 在远程计算机中跟踪文件。但是我发现程序退出后, "tail -f" 进程仍在远程计算机中。 如果我删除“-f”参数,一切正常。
我试过使用 "sendSignal()",但没用。似乎该功能未由 OpenSSH 实现。
这是测试代码。
public static void main(String[] args) throws Exception {
String usr = args[0];
String host = args[1];
String password = args[2];
JSch jsch = new JSch();
Session session = jsch.getSession(usr, host);
String pwd = password;
session.setPassword(pwd);
Hashtable<String, String> config = new Hashtable<String, String>();
config.put("StrictHostKeyChecking", "no");
session.setConfig(config);
session.connect(15000);
session.setServerAliveInterval(15000);
ChannelExec m_channelExec = (ChannelExec) session.openChannel("exec");
String cmd = "tail -f /var/log/messages";
m_channelExec.setCommand(cmd);
InputStream m_in = m_channelExec.getInputStream();
m_channelExec.connect();
BufferedReader m_bufferedReader = new BufferedReader(new InputStreamReader(m_in));
int i = 0;
while (++i < 10) {
if (m_bufferedReader.ready()) {
String line = m_bufferedReader.readLine();
System.out.println(line);
}
Thread.sleep(1000);
}
m_bufferedReader.close();
m_channelExec.sendSignal("SIGINT");
m_channelExec.disconnect();
session.disconnect();
System.out.println("exit");
}
有解决这个问题的方法吗?
execCommand 不 将控制 tty 分配给通道,因此 tail 实际上是在写入管道。它会继续,直到有更多数据发送给它(它会得到一个 SIGPIPE)。
最简单的解决方案是分配一个 tty - 使用:
m_channelExec.setPty(true);
在 m_channelExec.connect();
这应该会给你想要的行为。