2013-02-28 83 views
2

我有一个运行星号的Linux服务器,我想知道它是重新启动还是服务器发生了什么,所以我编写了一个Java应用程序来读取控制台。像这里(http://www.coderanch.com/t/556707/java/java/connect-Linux-Java-code);这是一个非常好的例子。使用java远程登录到Linux系统并运行“grep”

但这里有一个问题:

 String user=host.substring(0, host.indexOf('@'));  
    host=host.substring(host.indexOf('@')+1); 

    Session session=jsch.getSession(user, host, 22); 
    UserInfo ui=new MyUserInfo(); 
    session.setUserInfo(ui); 
    session.connect(); 

    String command= "asterisk -rvvv | grep 'Disconnect' "; 

    Channel channel=session.openChannel("exec"); 
    ((ChannelExec)channel).setCommand(command); 

    channel.setInputStream(null); 

    ((ChannelExec)channel).setErrStream(System.err); 

    InputStream in=channel.getInputStream(); 

    channel.connect(); 
while(in.available()==0){ 
     int i=in.read(tmp, 0, 1024); 
     if(i<0) 
     {break;} 
     System.out.print("-"+new String(tmp, 0, i)); 

    } 

当我执行asterisk -rvvvvv | grep 'Disconnect,它给了我一个空白行,该代码读取由排安慰行。所以如果我在这个空行之后得到任何数据,没有任何东西给我。计划坚持在那里。所以我需要在空白行之后阅读第二行。 console example 或任何想法读取此'Disconnect'字符串?

我的主要目的 - “星号重启了吗?” - 因为当星号重新启动时,给出这样的字符串,我们不知道为什么星号重新启动!

+0

尝试[JSch](http://www.jcraft.com/jsch/)。 – 2013-02-28 16:23:45

+0

已经在使用JSch:D – Acablack 2013-02-28 16:27:37

+0

嗯,从示例Shell和Sudo没有提供类似的功能? – 2013-02-28 16:47:38

回答

0

你可以使用:asterisk -rvvvv | grep -v ^$ | grep 'Disconnect' grep命令将

+0

哇,这是很好的一个谢谢,周末后我会尝试。谢谢。 – Acablack 2013-03-01 18:18:34

+0

不行,谢谢花时间给我。 – Acablack 2013-03-07 09:05:16

0

我使用jsch删除空行。你需要等待足够的时间来获得缓冲区,所以需要使用try {Thread.sleep(1000);} catch(Exception ee){}。至少我是这样使用的。

while(true){ 
     while(in.available()>0){ 
      int i=in.read(tmp, 0, 1024); 
      if(i<0)break; 
      System.out.print(new String(tmp, 0, i)); 
     } 
     if(channel.isClosed()){ 
      System.out.println("exit-status: "+channel.getExitStatus()); 
      break; 
     } 
     try{Thread.sleep(1000);}catch(Exception ee){} 
     } 
     channel.disconnect(); 
     session.disconnect(); 
    } 
    catch(Exception e){ 
     System.out.println(e); 
    } 
    } 
+0

感谢您的回复,但这是我想要的。问题是空白行,所以它给我in.read(tmp,0,1024)= 0,所以永远不会读取下面的行/行。 – Acablack 2013-03-01 06:49:23