2013-05-14 7 views
5

Sto utilizzando la libreria JSch per elencare e scaricare file da un server SFTP.
Channel channel = this.session.openChannel(SFTP_CHANNEL_NAME);
channel.connect();
sftpChannel = (ChannelSftp) channel;
Vector listing = sftpChannel.ls("*");
Configurazione del timeout su JSch Channel Operazioni con ilftftp

Durante la chiamata ls, thread dell'applicazione è conficcato volte.

discarica Discussione -
Thread 15108: (state = BLOCKED)
java.lang.Object.wait(long) @bci=0 (Compiled frame; information may be imprecise)
java.io.PipedInputStream.read() @bci=142, line=310 (Compiled frame)
java.io.PipedInputStream.read(byte[], int, int) @bci=43, line=361 (Compiled frame)
com.jcraft.jsch.ChannelSftp.fill(byte[], int, int) @bci=17, line=2527 (Compiled frame)
com.jcraft.jsch.ChannelSftp.header(com.jcraft.jsch.Buffer, com.jcraft.jsch.ChannelSftp$Header) @bci=12, line=2553 (Interpreted frame)
com.jcraft.jsch.ChannelSftp.ls(java.lang.String) @bci=298, line=1424 (Interpreted frame)

C'è un modo per configurare il timeout sul ls e altri metodi? Ho visto il timeout di impostazione su channel.connect(timeout) ma questo imposta solo il timeout durante la connessione al server remoto.

risposta

1

Controllare il codice sorgente jsch, non sembra possibile. Ma dopo tutto è open source, dovresti essere in grado di implementarlo. Dai un'occhiata all'inizializzazione dei flussi in ChannelSftp.start. Puoi modificare la tua implementazione con timeout personalizzabili.

4

Il modo corretto per evitare che i comandi vengano bloccati è impostare serverAliveInterval sulla sessione. Dal codice sorgente:

/** 
    * Sets the interval to send a keep-alive message. If zero is 
    * specified, any keep-alive message must not be sent. The default interval 
    * is zero. 
    * @param interval the specified interval, in milliseconds. 
    * @see #getServerAliveInterval() 
    */ 
    public void setServerAliveInterval(int interval) throws JSchException { 
    setTimeout(interval); 
    this.serverAliveInterval=interval; 
    } 
0

Anche se javadoc dice in millis, penso che in realtà funzioni in pochi secondi. https://epaul.github.io/jsch-documentation/simple.javadoc/com/jcraft/jsch/Session.html#setServerAliveInterval-int-

  ChannelSftp sftpChannel = (ChannelSftp)session.openChannel("sftp"); 
      sftpChannel.connect(); 
      System.out.println("SFTP Channel created.");   
      session.setServerAliveInterval(3); 
      filelist = (Vector<ChannelSftp.LsEntry>) sftpChannel.ls("*"); 

Questo codice funziona come previsto e timeout in 3 secondi

+0

Nella mia versione, che è 0.1.53, il parametro 'setServerAliveInterval' viene interpretato come specificato nella documentazione, in ** ** millisecondi. – bskp

Problemi correlati