UDP Server - mehrere Pakete auf einmal

flash2910

Mitglied
hallo zusammen,

ich habe mich gerade gefragt was ein DatagramSocket macht, wenn mehrere pakete fast gleichzeitig ankommen. gehen mir unter umständen pakete verloren, wenn ich die abfrage ungefähr so realisiere?:
Code:
while(true) {
receive();
daten_an_anderes_objekt_weitergeben();
}

oder gibts da grundsätzlich ne bessere lösung?
ich habe mir überlegt, ob man vielleicht jedem Client einen eigenen Port zuweist und dann viele Receiver-Objekte erzeugen, von dem jeder an einem Port horcht(also für jeden Client nen Receiver-Objekt).

Freue mich auf Anregungen

Grüße

Ich
 

HoaX

Top Contributor
Bis zu einem gewissen Maß werden die Pakete von Nic/OS gepuffert. Wenn der Puffer voll ist, dann werden Pakete weggeworfen.
 

flash2910

Mitglied
hm, klingt gut. wie groß ist der buffer ca? =) sehr groß muss er nicht sein, meine datenpakete sind sehr klein(nie über 1kB) und ein Übertragungsbefehl dürfte nicht sehr lange dauern. sollte also eigentlich mit der while(true) schleife funktionieren oder?
 

HoaX

Top Contributor
Das hängt von der Nic/OS ab, aber ich würde so vom gefühl der von >=16kb ausgeben.
Aber das kannst du ja lokal einfach mal ausprobieren.
 
G

Gast2

Gast
Thread 1
Java:
while(!ende)
{
    byte [] data = empfange_paket();
    queue.enqueue(data);
}

Thread 2
Java:
while(!ende)
{
    byte[] data = queue.dequeue();
    verarbeitet_data();
}
schützt zwar immer noch nicht 100% vor Paketverlust ... allerdings hast Du einen Thread der direkt nur den Socket bedient ... ggf. muss due die Queue noch Synchronisieren
 

flash2910

Mitglied
hmm, folgende idee:

Receiver-Thread:
Code:
while(true) {
data=receive();
engine.add(data);
}

Engine-Thread:
Code:
byte[100][1000] buffer;
int pointer=0;
int length=0;

add(byte[1000] p) {
buffer[pointer]=p;
pointer++;
length++;
if(pointer==100) pointer=0;
if(length==101) length=100; //bei mehr als hundert elementen überlauf, el. werden gelöscht
}

byte[1000] get() {
if(length!=0) {
length--;
pointer--;
if(pointer==-1) pointer=99;
}
return buffer[pointer];
}

run() {
byte[1000] workdata;
while(true) {
workdata=get();
/*
workworkwork
workworkworkwork
*/
}
}

gute idee, schlechte idee? =)
 
G

Gast2

Gast
schlechte Idee ... weil Du viel mehr Synchronisieren musst ... ich glaube Java hat schon eine Queue die synchronisiert ... wenn nicht - ist auch mit entsprechendem Schlüsselwort schnell geschrieben
 

flash2910

Mitglied
was meinst du mit viel mehr? vom programmier- oder vom rechenaufwand?
weil ich denke der rechenaufwand ist so ziemlich minimiert. wenn ein
neues paket eintrifft, wird es in den buffer geschrieben.
die verarbeitungsroutine arbeitet währendessen mit ihrem eigenen tempo.
klappt doch prima.
schreib wenn ich falsch liege
 

flash2910

Mitglied
hm, habs mal so programmiert wie ich das geschrieben habe und so wie mogel mir das vorgeschlagen hat(hab die Klasse queue aber noch nie verwendet, deshalb mit nem array, aber ändert ja nichts), allerdings geht die Prozessorauslastung voll hoch, wohl wegen der Endlosschleife

Code:
while(!ende)
{
    byte[] data = queue.dequeue();
    verarbeitet_data();
}

bzw.

Code:
while(true) { //hier geht die auslastung hoch, da die Schleife einfach endlos rennt
workdata=get();
/*
workworkwork
workworkworkwork
*/
}

hat irgend jemand ne idee wie man das besser machen könnte?
 
G

Gast2

Gast
ja - 2. Thread schlafen legen wenn nichts mehr ansteht ... der 1. Thread kann ihn dann ja aufwecken wenn wieder Arbeit da ist
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
izoards Mehrere TCP Verbindungen auf einen Server [alles Local] Netzwerkprogrammierung 2
J Framework mehrere Clients/ Server-Broadcast/oracle XE/ XML Netzwerkprogrammierung 1
V Server / mehrere Clients / MySQL / Konzept Netzwerkprogrammierung 2
S Server - Mehrere Klassen sollen Daten senden und empfangen Netzwerkprogrammierung 25
Z Socket [Chatprogramm] Mehrere Clients an einen Server Netzwerkprogrammierung 10
V Authentifikation über mehrere Server? Netzwerkprogrammierung 3
G Socket Mehrere Clientanmeldungen am Server Netzwerkprogrammierung 13
cedi Socket Mehrere Clients an einem Server Netzwerkprogrammierung 4
F Socket Verbindungen über mehrere Server Netzwerkprogrammierung 4
L Socket Chat Server für mehrere Clients Netzwerkprogrammierung 7
A Mit Client auf mehrere Server zugreifen Netzwerkprogrammierung 5
G Server an mehrere Clients Netzwerkprogrammierung 15
F http Post auf einen Grafana Server Netzwerkprogrammierung 3
W Socket Server -> lesen von / schreiben zu php-script Netzwerkprogrammierung 6
E Server mit GUI Netzwerkprogrammierung 4
E FTP FTPS Server gibt Fehlernachricht "522 SSL/TLS required on the data channel" zurück Netzwerkprogrammierung 1
I Performanteste Kommunikationsmethode zwischen Client u. Server Netzwerkprogrammierung 4
L Socket Automatische Zuweisung von Server und Client Rolle Netzwerkprogrammierung 12
Eigenen Rechner als Server? Netzwerkprogrammierung 16
FrankenDerStein HTTP Https Server Bibliothek für Linux und Android gesucht. Netzwerkprogrammierung 7
ExceptionOfExpectation Server/Client-Kommunikation Netzwerkprogrammierung 34
M Server-Client-System für Browsergame Netzwerkprogrammierung 5
J Datei Download vom Server Netzwerkprogrammierung 8
Yonnig Threads mit Client/Server und GUI (laufend bis button-click) Netzwerkprogrammierung 9
J Client-Server und SOAP Netzwerkprogrammierung 23
K Threads/Server/telnet Fehler Netzwerkprogrammierung 2
J Multithreaded-Server Netzwerkprogrammierung 21
JaXnPriVate Java HTTPS Server (Secure Sockets) Netzwerkprogrammierung 15
L30nS RMI RMI-Server kann Dialog nicht volkommen anzeigen Netzwerkprogrammierung 2
L30nS RMI Aufruf einer Client-Methode von einem RMI-Server Netzwerkprogrammierung 3
L Server-Socket liest Input-Stream nicht Netzwerkprogrammierung 5
T String von Client zu Server kommt nicht an Netzwerkprogrammierung 92
D WebSocket Server mit HTML Client und Java Server Netzwerkprogrammierung 5
S Von Java auf passwortgeschützten Server zugreifen + Umgang mit Ports Netzwerkprogrammierung 28
S Probleme bei Java-Installation auf Server (Linux/Shell/Terminal) Netzwerkprogrammierung 6
S Java: Anbindung an einen realen Server? (+ Portfreigabe) Netzwerkprogrammierung 8
D Server - Client Informationsaustausch, Möglichkeiten Netzwerkprogrammierung 3
H Socket Kann ein Socket server 2 dimensionale Arrays empfangen und versenden? Netzwerkprogrammierung 3
H Socket Chat entwickeln mit Java Server Client Netzwerkprogrammierung 4
X Kann ich einen Client/Server verbindung hinkriegen die mir alle paar Sekunden die aktuellen Daten per Realtime zuschickt ? Netzwerkprogrammierung 9
Z Kann nicht Daten vom Server lesen Socket Netzwerkprogrammierung 10
S HTTP Post?!? - Java Server Netzwerkprogrammierung 7
F Verbindung zu einem LDAP Server über Java Netzwerkprogrammierung 4
D Slf4j - Logging - Client-Server Architektur Netzwerkprogrammierung 3
F NodeJs-Server auf Firebase hosten ? Netzwerkprogrammierung 3
J client server mit nur einem PC Netzwerkprogrammierung 33
M Socket Nachricht von TCP-Client an Server schicken Netzwerkprogrammierung 12
M Socket Verbindung Matlab(Server) Java(Client) Netzwerkprogrammierung 1
H HTTP Glassfish (v5) Application Server - Bibliothek zur Verfügung stellen Netzwerkprogrammierung 4
B HttpClient - Server (Jetty) - getInputStream - EOF Netzwerkprogrammierung 3
P TCP-Server Netzwerkprogrammierung 1
R Socket FATAL EXCEPTION MAIN bei Socket based client/server app Netzwerkprogrammierung 2
F Server für Java Applikationen Netzwerkprogrammierung 16
H Einfacher Server funktioniert nicht Netzwerkprogrammierung 1
G Server-Client IO Problem Netzwerkprogrammierung 6
T Mikrofonaudio über Java Server an Webbrowser streamen Netzwerkprogrammierung 13
I Socket Das erste Server-Client Programm Netzwerkprogrammierung 16
T HTTPS-Requests an Server: POST-Parameter kommen nicht an Netzwerkprogrammierung 5
L Socket Wie kann ich checken ob ein User eine Nachricht per Outputstream an den Server gesendet hat? Netzwerkprogrammierung 1
T Jetty Server LOGGING Netzwerkprogrammierung 1
L Strings an Server senden und in MYSQL speichern? Netzwerkprogrammierung 3
Aruetiise Socket Java Programm auf Server Netzwerkprogrammierung 3
T server empfängt nur 1 Buchstaben vom String Netzwerkprogrammierung 1
S Spiel mit Server programmieren Netzwerkprogrammierung 2
N Post u Head Request an Server Netzwerkprogrammierung 4
J Socket Ein Chat Server Tutorial Netzwerkprogrammierung 8
M Socket Server antwortet dem Client nicht Netzwerkprogrammierung 6
J Socket Tutorial zu Multiplayer Server schreiben? Netzwerkprogrammierung 5
S Java Chat Server Netzwerkprogrammierung 8
E Kurze Textnachrichten über einen Server von meinem Handy auf den Computer laden. Netzwerkprogrammierung 9
I Client/Server Kommunikation bei einem Spiel Netzwerkprogrammierung 4
E Objekte versenden, Client-Server Netzwerkprogrammierung 25
C Mini Client-Server-Anwendung funktioniert nicht Netzwerkprogrammierung 8
D Socket Message an einen Server senden? Netzwerkprogrammierung 8
J FTP FTP Zugriff über Proxy Server Netzwerkprogrammierung 1
KaffeeFan Programmierung mit Cloud-Server Netzwerkprogrammierung 0
L Socket Problem mit Server Netzwerkprogrammierung 1
cezary Socket Paralleler Server ? Netzwerkprogrammierung 1
I Socket Leicht zu DDosender Server Netzwerkprogrammierung 4
agent47 HTTPs Server Netzwerkprogrammierung 5
J Chat Server starten über GUI problem Netzwerkprogrammierung 4
J Prüfen, ob remote UDT Server erreichbar ist Netzwerkprogrammierung 0
P Server als Client nutzen Netzwerkprogrammierung 8
S Server Kommunikation Netzwerkprogrammierung 1
V einfaches hin und her von Text über Server Netzwerkprogrammierung 2
D Socket Run Args Client/Server Socket Netzwerkprogrammierung 1
Cromewell Socket Multithreaded Server und Client Netzwerkprogrammierung 1
Y Client/Server/DB communication Netzwerkprogrammierung 3
JavaWolf165 Socket mit .writeUtf etwas vom Client zum Server schicken Netzwerkprogrammierung 13
P RMI Client Server Programm über Internet Netzwerkprogrammierung 2
brainless Client Server Kommunikation verschlüsseln Netzwerkprogrammierung 13
gamebreiti Socket Server / Client Anwendung Manipulation von Objekten durch Server Netzwerkprogrammierung 9
T Socket Server/Client Kommunikation Netzwerkprogrammierung 8
S Webservice - Server Netzwerkprogrammierung 0
M Java Eingabe auf FTP Server übergeben Netzwerkprogrammierung 4
F Server Client Anwendung mit UDP Netzwerkprogrammierung 2
A RMI Wo treten Exceptions bei RMI Aufrufen auf? Auf Client oder auf Server? Netzwerkprogrammierung 3
M Socket Java Server: NullPointerException Netzwerkprogrammierung 4
A ByteBuffer - Client/Server Netzwerkprogrammierung 9
J Java Server empfängt php inhalt nicht Netzwerkprogrammierung 1

Ähnliche Java Themen

Neue Themen


Oben