Socket NIO2 Problem mit AsynchronousSocketChannel beim Schließen

Grizzly

Top Contributor
Hallo alle zusammen, :)

ich kämpfe mit der Klasse [JAPI]AsynchronousSocketChannel[/JAPI] bzw. ihrem verhalten. Und zwar ist mir aufgefallen, dass beim Schließen derselbigen nicht in allen Fällen die Daten, die ich über diese geschrieben / abgesetzt habe, übertragen werden. In manchen Fällen kommen die letzten zur Übertragung übergebenen Daten bei der Gegenstelle einfach nicht an. Wenn ich einen Thread.sleep(1000); zwischen der letzten Übergabe und dem Schließen einbaue, funktioniert wunderbar. Dass das Problem nicht immer auftritt, wird wahrscheinlich an irgendwelchen Nebenläufigkeiten liegen, vermute ich einmal.

Um etwas mehr ins Detail zu gehen: Ich übergebe der write Methode des Channels die Daten inkl. einem [JAPI]CompletionHandler[/JAPI]. Dieser fragt nach einem erfolgreich Schreiben ab, ob alle Daten geschrieben wurde. Wenn nein, wird versucht den Rest zu versenden. Wenn ja, wird eine Queue abgefragt, ob noch weitere Daten anliegen und wenn ja, werden diese mit einem weiteren write Aufruf versendet. Holt sich der Handler ein spezielles Schließ-Paket aus der Queue, wird innerhalb des Handlers der Channel geschlossen und der Verarbeitung signalisiert, dass die Verbindung beendet wurde.



Hier ist ein Blog Eintrag, der ein ähnliches Problem bei [JAPI]AsynchronousFileChannel[/JAPI] beschreibt. Leider lässt sich die Lösung, so weit ich es gesehen habe, nicht auf [JAPI]AsynchronousSocketChannel[/JAPI] übertragen.
Niklas' Blog: Java 7: Closing NIO.2 file channels without loosing data



Hat jemand von Euch schon mit ähnlichen Problemen zu kämpfen gehabt?
 

Nightmares

Aktives Mitglied
Das Problem hab ich jetzt nicht direkt, weil meine Implementierung damit endet, das der Client die Verbindungen schließt wenn er fertig ist und zuvor eine "Abmeldung" schickt und der Server die Verbindung nur schließt, wenn der Client sich illegal verhält / zu viele Fehler produziert oder geblockt wird.

Ich könnte mir aber vorstellen, dass auch wenn dein Schreibvorgang als fertig angezeigt wird (der zu schreibene Buffer leer ist) evtl. noch was in einem VM Buffer u.O. nativen Buffer ist und noch nicht fertig geschickt wurde (der Versuch mit einem sleep() deutet stark darauf hin. (EDIT: ... da ja alles async. läuft) EDITENDE)

Als Lösung könntest du auf eine Bestätigung vom Client warten, dass alles angekommen ist oder eine "Shutdown Benachrichtigung" schicken und auf antwort warten, falls keine innerhalb von x Sekunden kommt automatisch schließen. Es ist ja nicht so, dass ein Verbindung, die bei NIO etwas länger aufbleibt einen großen Performanz Verlust darstellt.

EDIT2: Ich versuch mal ob ich das Problem repliziert kriege, interressiert mich auch...
EDIT3: Das Problem kann ich bestätigen... Eine Serverseitige Lösung hab ich dafür jetzt aber auch nicht... nur die Idee für die "Shutdown Benachrichtigung" oder halt abwarten...
 
Zuletzt bearbeitet:

Grizzly

Top Contributor
Leider geht es in dem Fall um die Verarbeitung von HTTP Paketen. Da bleibt nur abwarten, da ich mich an den Standard halten muss. :-(
 

Nightmares

Aktives Mitglied
Ahso, das konnte ich aus deinem ersten Post ja nicht lesen. Vielleicht mal angucken wie das Problem in bekannten Frameworks, die HTTP unterstützten (netty & mina) gelöst wurde? Ich schreibe zwar beruflich Netzwerk Anwendungen, allerdings keine die HTTP benutzen/unterstützen.
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
I Socket Problem mit den WebSocket Antworten der Discord API Netzwerkprogrammierung 0
K Java Websocketserver Problem | Android to Pi Netzwerkprogrammierung 1
C RMI Produzent-Verbraucher-Problem - Code review Netzwerkprogrammierung 12
B Socket Bilder verschicken via Sockets. Heap-Problem. Netzwerkprogrammierung 2
S Problem bei dem Bluetoothverbindungsaufbau Netzwerkprogrammierung 2
G Server-Client IO Problem Netzwerkprogrammierung 6
M Netty - TCP Problem Netzwerkprogrammierung 4
L Socket Problem mit Server Netzwerkprogrammierung 1
J Chat Server starten über GUI problem Netzwerkprogrammierung 4
M Problem bei Socket (MultiplayerSpiel) Netzwerkprogrammierung 4
M Socket CDI, Websocket reference Problem ! Netzwerkprogrammierung 2
Shams Problem mit Eventbus in Verbindung mit Server Netzwerkprogrammierung 0
G apache httpClient Problem. Netzwerkprogrammierung 5
H Problem mit ObjectStreams Netzwerkprogrammierung 3
A Problem beim Senden von Client zu Server Netzwerkprogrammierung 10
D Socket BufferedWriter/Reader Problem Netzwerkprogrammierung 1
Maxim6394 Problem mit Socks5 Implementierung Netzwerkprogrammierung 0
C Handle Connection Problem Netzwerkprogrammierung 3
E HttpUrlConnection Cookie Problem Netzwerkprogrammierung 0
X Problem mit vielen Bytes über Socket Netzwerkprogrammierung 23
O 4Gewinnt Multiplayer - Netzwerk Problem (TCP) Netzwerkprogrammierung 1
A Socket Socket-Problem - Object wird nicht übertragen Netzwerkprogrammierung 3
R Problem beim Programmieren eines Chatprogramms Netzwerkprogrammierung 5
E einfaches Problem: Session-Handling bei Servlets Netzwerkprogrammierung 5
G Problem mit einem FileWatcher Netzwerkprogrammierung 7
T Socket Server starten Thread Problem Netzwerkprogrammierung 12
B Client/Server Connection Problem Netzwerkprogrammierung 2
G Problem mit STATIC-Verständnis Netzwerkprogrammierung 8
S Umstellung AS400 auf Postgre - Problem beim Arbeiten mit Metadaten Netzwerkprogrammierung 2
J Facelets Include Rendered Problem Netzwerkprogrammierung 2
J Socket Problem mit C++/Java Netzwerkprogrammierung 20
P Problem mit Datagram-Sockets Netzwerkprogrammierung 2
G Cookie Verwaltungs Problem nach Login auf InetSeite (Wo utma-Cookie?) Netzwerkprogrammierung 18
C Socket Problem mit ObjectInput/OutputSream Netzwerkprogrammierung 7
B Socket Problem mit Netzwerkchat Netzwerkprogrammierung 21
D RMI Problem beim shutdown von verteilter CORBA-Anwendung Netzwerkprogrammierung 6
Maxim6394 ipv6 Problem Netzwerkprogrammierung 2
Maxim6394 Proxyserver Performance Problem Netzwerkprogrammierung 11
M Problem Client - Server Sockets: .ready() wird nie true! Netzwerkprogrammierung 6
C Socket Problem mit ObjectInput/OutputSream Netzwerkprogrammierung 5
B RMI und Problem mit rmic-Tool Netzwerkprogrammierung 3
C FTP storeFileStream Problem Netzwerkprogrammierung 3
N Problem über http eine Datei zu senden Netzwerkprogrammierung 4
D JavaMail - Mailsabrufen Problem (imap) Netzwerkprogrammierung 12
J HTTP Übersetzung yahoo babelfish - Zeichensatz-Problem Netzwerkprogrammierung 6
D Apache CXF, JAX-WS Problem bei Arrays - einfacher Server Netzwerkprogrammierung 2
M Problem beim Datenempfang Netzwerkprogrammierung 2
X Problem mit Server-Client-Kommunikation Netzwerkprogrammierung 14
M Problem mit Socket-Verbindung Netzwerkprogrammierung 2
N NIO Problem beim speziellen Behandeln von einzelnen Benutzern Netzwerkprogrammierung 13
D Thread problem Netzwerkprogrammierung 3
T Servlets JSP: Tomcat Problem Netzwerkprogrammierung 4
K Client - Server Problem Netzwerkprogrammierung 16
T RMI Problem Client-Server Netzwerkprogrammierung 2
P RMI Stub Problem Netzwerkprogrammierung 3
D Socket UDP Übertragungs Problem Netzwerkprogrammierung 7
I HTTP Post aus html in Java einlesen - Problem Netzwerkprogrammierung 2
I HTTP Post aus html in Java einlesen - Problem Netzwerkprogrammierung 6
D Problem mit ObjectInputStreams Netzwerkprogrammierung 10
D Socket Problem mit InputStreamReader Netzwerkprogrammierung 3
N CRC32 CheckSum Problem bei UDP Netzwerkprogrammierung 2
V Java Mail Api - IMAP Problem Netzwerkprogrammierung 6
P RMI Problem Netzwerkprogrammierung 4
I Problem bei Outputstreamerzeugung in anderer Klasse als Socket Netzwerkprogrammierung 5
S Socket Problem mit Objektübertragung Netzwerkprogrammierung 16
Shoox Reader / Writer Problem Netzwerkprogrammierung 2
S Problem mit 2 Serversockets unter Win XP Netzwerkprogrammierung 7
P Socket Problem mit Netzwerkverbindung über TCP Netzwerkprogrammierung 12
M RMI - Connection Problem Netzwerkprogrammierung 7
J Socket Client - Server Problem Netzwerkprogrammierung 4
M Socket Chat-Client-Problem Netzwerkprogrammierung 8
D Client Server Problem, Methode readline() löst SocketException "Connection reset" aus Netzwerkprogrammierung 8
E HTTP Problem beim Auslesen von Websiten Netzwerkprogrammierung 6
T Problem bei Findung der richtigen Architektur Netzwerkprogrammierung 3
AlexSpritze Authentication Problem bei WebServices Netzwerkprogrammierung 4
J Socket Problem -Proxies Netzwerkprogrammierung 2
R HTTP Problem bei Authentifizierung über (Http)UrlConnection Netzwerkprogrammierung 2
F Konzept Problem Netzwerkprogrammierung 12
G NIO Sockets Architektur Problem Netzwerkprogrammierung 2
H Neues NIO problem nachricht an alle clients Netzwerkprogrammierung 3
J Client server problem Netzwerkprogrammierung 3
S Problem bzgl. Sockets / Server-Client-Struktur Netzwerkprogrammierung 3
W RMI Problem Netzwerkprogrammierung 4
M Problem mit Server Netzwerkprogrammierung 5
N Socket Java server c# client problem Netzwerkprogrammierung 7
Y Problem mit ObjectInputStream beim lesen vom Socket Netzwerkprogrammierung 10
R RMI Hibernate Problem Netzwerkprogrammierung 4
Z RMI Problem Netzwerkprogrammierung 11
F RMI problem mit RMI Netzwerkprogrammierung 3
H Object Cast Problem nach Übertragung mit Log4j Netzwerkprogrammierung 5
H Log4j SocketAppender Problem Netzwerkprogrammierung 2
P HTTP Problem beim Download von einer Datei Netzwerkprogrammierung 4
P Problem mit JOscarLib Netzwerkprogrammierung 6
0din SMTP Client - readline problem Netzwerkprogrammierung 4
C komisches Problem / ObjectInputStream erstellt sich nicht Netzwerkprogrammierung 5
W vista / win server 2003 netzlaufwerk problem Netzwerkprogrammierung 4
W Problem mit HTTP-Dateiübertragung Netzwerkprogrammierung 6
E Problem: netbeans 6.5 und webanwendung Netzwerkprogrammierung 6
C Problem mit Übertragung einer Klasse in RMI Netzwerkprogrammierung 10
B UDP Problem Netzwerkprogrammierung 25

Ähnliche Java Themen

Neue Themen


Oben