JSch 명령 출력 읽기 문제 이해
JSch를 사용하여 제공된 Java 코드에서 읽기를 시도하는 동안 프로그램이 중단되는 상황이 발생합니다. 명령 출력을 캡처하는 데 사용되는 리더 스트림에서. 이 글에서는 이 문제의 원인을 설명하고 해결책을 제시합니다.
문제 분석
기본적인 문제는 실행된 명령으로 생성된 출력을 지속적으로 소비하지 않는 데서 발생합니다. JSch 명령은 내부 버퍼에 출력을 축적하며, 버퍼가 사용되기 전에 가득 차면 버퍼가 지워질 때까지 명령이 중단되는 교착 상태가 발생할 수 있습니다.
해결 방법
이 문제를 해결하려면 명령이 완료될 때까지 기다리는 동안에도 명령의 표준 출력과 표준 오류 스트림을 지속적으로 읽어야 합니다. 이렇게 하면 출력 버퍼가 채워지지 않고 명령이 중단되지 않습니다.
예제 코드
다음은 이 솔루션을 통합하는 확장 버전의 코드입니다.
<code class="java">ChannelExec channel = (ChannelExec)session.openChannel("exec"); channel.setCommand(...); // Set the command to execute ByteArrayOutputStream outputBuffer = new ByteArrayOutputStream(); ByteArrayOutputStream errorBuffer = new ByteArrayOutputStream(); InputStream in = channel.getInputStream(); InputStream err = channel.getExtInputStream(); channel.connect(); byte[] tmp = new byte[1024]; while (true) { while (in.available() > 0) { int i = in.read(tmp, 0, 1024); if (i < 0) break; outputBuffer.write(tmp, 0, i); } while (err.available() > 0) { int i = err.read(tmp, 0, 1024); if (i < 0) break; errorBuffer.write(tmp, 0, i); } if (channel.isClosed()) { if ((in.available() > 0) || (err.available() > 0)) continue; System.out.println("exit-status: " + channel.getExitStatus()); break; } try { Thread.sleep(1000); } catch (Exception ee) { } } System.out.println("output: " + outputBuffer.toString("UTF-8")); System.out.println("error: " + errorBuffer.toString("UTF-8")); channel.disconnect();</code>
이 예에서 while 루프는 명령(channel.isClosed())의 상태를 모니터링하면서 출력 스트림(in 및 err)을 지속적으로 읽습니다. 이렇게 하면 명령이 많은 양의 데이터를 생성하는 경우에도 모든 출력이 캡처됩니다.
위 내용은 출력을 읽는 동안 JSch 명령이 중단되는 이유는 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!