我正在通过JSch在java上建立一个ssh连接,一切似乎工作正常,直到我试图运行这个.sh文件. shell脚本的名称是repoUpdate.sh,它非常简单:

echo  ' ****Repository update****'
echo  ' Location: /home/cissys/repo/'
echo -e ' Command: svn update /home/cissys/repo/2.3.0'

svn update /home/cissys/repo/2.3.0

这是我直接在linux控制台上得到的输出,并带有正确的命令响应:

[cissys@dsatelnx5 ~]$repoUpdate.sh
 ****Repository update****
 Location: /home/cissys/repo/
 Command: svn update /home/cissys/repo/2.3.0

At revision 9432.

现在,这是我的方法的java代码,其中ssh连接试图调用同一个文件

public void cmremove()
{
    try
    {
        JSch jsch = new JSch();
        Session session = jsch.getSession(user, host, port);
        UserInfo ui = new SUserInfo(pass, null);
        session.setUserInfo(ui);
        session.setPassword(pass);
        session.connect();

        ChannelExec channelExec = (ChannelExec)session.openChannel("exec");

        InputStream in = channelExec.getInputStream();

        channelExec.setCommand("./repoUpdate.sh");
        channelExec.connect();

        BufferedReader reader = new BufferedReader(new InputStreamReader(in));
        String line;
        int index = 0;

        while ((line = reader.readLine()) != null)
        {
            System.out.println(++index + " : " + line);
        }

        channelExec.disconnect();
        session.disconnect();

        System.out.println("Done!");
    }
    catch(Exception e)
    {
        System.err.println("Error: " + e);
    }
}

我得到的回应如下:


run:
1 :  ****Repository update****
2 :  Location: /home/cissys/repo/
3 :  Command: svn update /home/cissys/repo/2.3.0
Done!
BUILD SUCCESSFUL (total time: 2 seconds)

没有输出或svn命令执行的迹象(在修订版9432).

我想它可能会在某个时候关闭会话,而不是让命令正确执行.如果updateRepo.sh文件有类似“cp test.txt test\_2.txt”的东西,那么它就可以毫无问题地完成.但我只对这个和其他一些特定的.sh文件有这个问题.

任何帮助,将不胜感激.

解决方法:

我怀疑你的shell命令由于某种原因出错了 – 也许svn不在你的路径上,也许还有其他奇怪的环境影响 – 但你没有得到错误输出,因为你没有找到它.通常,在从channelExec.getErrStream获取的流上发送错误,但在您的代码中,您只能从getOutputStream流中读取错误.

要诊断这一点,您将需要获取这些错误消息.让你的一个流用于常规输出和错误消息比使你的java程序一次从两个流中拉出来更容易,所以我将这行添加为repoUpdate.sh的顶行:

exec 2>&1

然后,这将导致脚本的其余部分使用您正在读取的一个流作为输出和错误.

此外,在您调用chanelExec.disconnect之前,您应该在java程序中记录退出状态,然后更改“完成!”.消息基于它是什么:

    int exitStatus = channelExec.getExitStatus();
    channelExec.disconnect();
    session.disconnect();

    if (exitStatus < 0) {
        System.out.println("Done, but exit status not set!");
    } else if (exitStatus > 0) {
        System.out.println("Done, but with error!");
    } else {
        System.out.println("Done!");
    }

如果你这样做,你应该得到错误消息,告诉你为什么你的命令没有按预期运行.

标签: linux, java, ssh, command, jsch

相关文章推荐

添加新评论,含*的栏目为必填