Warum hängt mein JSch-Befehl beim Lesen der Ausgabe?
Informationen zu Leseproblemen bei JSch-Befehlsausgaben
In Ihrem bereitgestellten Java-Code mit JSch kommt es zu einer Situation, in der das Programm beim Leseversuch hängen bleibt aus einem Reader-Stream, der zum Erfassen der Befehlsausgabe verwendet wird. In diesem Artikel wird die Ursache dieses Problems erläutert und eine Lösung bereitgestellt.
Problemanalyse
Das grundlegende Problem entsteht dadurch, dass die durch den ausgeführten Befehl erzeugte Ausgabe nicht kontinuierlich verbraucht wird. JSch-Befehle sammeln die Ausgabe in einem internen Puffer, und wenn der Puffer voll ist, bevor er verbraucht wird, kann es zu einem Deadlock kommen, bei dem der Befehl hängen bleibt und darauf wartet, dass der Puffer gelöscht wird.
Lösung
Um dieses Problem zu beheben, müssen Sie kontinuierlich sowohl die Standardausgabe als auch die Standardfehlerströme des Befehls lesen, auch während Sie auf den Abschluss des Befehls warten. Dadurch wird sichergestellt, dass der Ausgabepuffer nie voll wird und der Befehl nicht hängen bleibt.
Beispielcode
Hier ist eine erweiterte Version Ihres Codes, die diese Lösung enthält:
<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>
In diesem Beispiel lesen die While-Schleifen kontinuierlich die Ausgabeströme (in und err) und überwachen gleichzeitig den Status des Befehls (channel.isClosed()). Dadurch wird sichergestellt, dass die gesamte Ausgabe erfasst wird, auch wenn der Befehl eine große Datenmenge erzeugt.
Das obige ist der detaillierte Inhalt vonWarum hängt mein JSch-Befehl beim Lesen der Ausgabe?. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Heiße KI -Werkzeuge

Undresser.AI Undress
KI-gestützte App zum Erstellen realistischer Aktfotos

AI Clothes Remover
Online-KI-Tool zum Entfernen von Kleidung aus Fotos.

Undress AI Tool
Ausziehbilder kostenlos

Clothoff.io
KI-Kleiderentferner

Video Face Swap
Tauschen Sie Gesichter in jedem Video mühelos mit unserem völlig kostenlosen KI-Gesichtstausch-Tool aus!

Heißer Artikel

Heiße Werkzeuge

Notepad++7.3.1
Einfach zu bedienender und kostenloser Code-Editor

SublimeText3 chinesische Version
Chinesische Version, sehr einfach zu bedienen

Senden Sie Studio 13.0.1
Leistungsstarke integrierte PHP-Entwicklungsumgebung

Dreamweaver CS6
Visuelle Webentwicklungstools

SublimeText3 Mac-Version
Codebearbeitungssoftware auf Gottesniveau (SublimeText3)

Heiße Themen

Fehlerbehebung und Lösungen für die Sicherheitssoftware des Unternehmens, die dazu führt, dass einige Anwendungen nicht ordnungsgemäß funktionieren. Viele Unternehmen werden Sicherheitssoftware bereitstellen, um die interne Netzwerksicherheit zu gewährleisten. ...

Lösungen zum Umwandeln von Namen in Zahlen zur Implementierung der Sortierung in vielen Anwendungsszenarien müssen Benutzer möglicherweise in Gruppen sortieren, insbesondere in einem ...

Die Verarbeitung von Feldzuordnungen im Systemdocken stößt häufig auf ein schwieriges Problem bei der Durchführung von Systemdocken: So kartieren Sie die Schnittstellenfelder des Systems und ...

Bei Verwendung von MyBatis-Plus oder anderen ORM-Frameworks für Datenbankvorgänge müssen häufig Abfragebedingungen basierend auf dem Attributnamen der Entitätsklasse erstellt werden. Wenn Sie jedes Mal manuell ...

Beginnen Sie den Frühling mit der Intellijideaultimate -Version ...

Konvertierung von Java-Objekten und -Arrays: Eingehende Diskussion der Risiken und korrekten Methoden zur Konvertierung des Guss-Typs Viele Java-Anfänger werden auf die Umwandlung eines Objekts in ein Array stoßen ...

Detaillierte Erläuterung des Designs von SKU- und SPU-Tabellen auf E-Commerce-Plattformen In diesem Artikel werden die Datenbankdesignprobleme von SKU und SPU in E-Commerce-Plattformen erörtert, insbesondere wie man mit benutzerdefinierten Verkäufen umgeht ...

Wenn Sie TKMybatis für Datenbankabfragen verwenden, ist das Aufbau von Abfragebedingungen ein häufiges Problem. Dieser Artikel wird ...
