TCP-Server soll viele offene Verbindungen verwalten

Status
Nicht offen für weitere Antworten.

elinmerl

Mitglied
Hallo allerseits!

Ich muss ein Programm entwickeln, welches viele (größer 1000) geöffnete Verbindungen verwalten kann.

Grundsätzlicher Aufbau wäre also:
Server wartet mit accept() auf eingehende Verbindungen.
Wird eine Verbindung aufgebaut, wird diese in eine Collection einsortiert und bleibt geöffnet.
Dann wartet der Server wieder auf eine neue Verbindung.

Die erste Frage die ich mir stelle, wie viele Verbindungen kann ich annehmen und offen halten?

Und das zweite Problem: Wie verwalte ich diese Verbindungen. Ich denke ja mal nicht, dass ich für jede Verbindung einen Thread öffnen kann. Falls doch, wäre mein Problem prinzipiell gelöst. :)
Wenn ich also keine Threads für jede Verbindung öffnen kann, muss ich die Verbindungen regelmäßig pollen um zu sehen ob Daten angekommen sind. Nur pollen bedeutet, dass ich CPU-Zeit vergeude. :(

Hat jemand eine andere Idee?

Andreas
 

Ebenius

Top Contributor
Probier's doch einfach aus. Zum Beispiel so:
Code:
/**
 * Test main method.
 * 
 * @param args ignored
 * @throws InterruptedException
 */
public static void main(String[] args) throws InterruptedException {
  final Runnable connectionHandlerFake = new Runnable() {

    @Override
    public synchronized void run() {
      try {
        wait();
      } catch (InterruptedException ex) {
        // interrupted
        return;
      }
    }
  };

  final Thread[] threads = new Thread[2000];
  final NumberFormat nf = new DecimalFormat("0000");
  final DateFormat df = new SimpleDateFormat("HH:mm:ss,SSS");

  System.out.println(df.format(new Date())
        + " [main thread] Creating and starting "
        + threads.length
        + " threads ...");
  for (int i = 0; i < threads.length; i++) {
    final Thread thread = new Thread(connectionHandlerFake);
    thread.setDaemon(true);
    thread.setName("Connection Handler " + nf.format(i));
    thread.start();
    threads[i] = thread;
  }
  System.out.println(df.format(new Date())
        + " [main thread] All threads created");

  new Thread(new Runnable() {

    @Override
    public void run() {
      try {
        System.out.println(df.format(new Date())
              + " [notifier thread] "
              + "Waiting for 10 seconds prior to notifyAll ...");
        Thread.sleep(10 * 1000);
        System.out.println(df.format(new Date())
              + " [notifier thread] Notifying all threads ...");
        synchronized (connectionHandlerFake) {
          connectionHandlerFake.notifyAll();
        }
        System.out.println(df.format(new Date())
              + " [notifier thread] All threads notified");
      } catch (InterruptedException ex) {
        ex.printStackTrace();
      }
    }
  }).start();

  System.out.println(df.format(new Date())
        + " [main thread] Joining all children");
  for (int i = 0; i < threads.length; i++) {
    threads[i].join();
  }
  System.out.println(df.format(new Date())
        + " [main thread] All children joined");
}

Mein Programm hat gesagt.:
14:50:29,039 [main thread] Creating and starting 2000 threads ...
14:50:29,510 [main thread] All threads created
14:50:29,511 [main thread] Joining all children
14:50:29,511 [notifier thread] Waiting for 10 seconds prior to notifyAll ...
14:50:39,518 [notifier thread] Notifying all threads ...
14:50:39,519 [notifier thread] All threads notified
14:50:39,617 [main thread] All children joined

Ebenius
 
T

tuxedo

Gast
1000 Threads? Das ist dann ja nicht mehr wirklich performant mit Java IO.

Würde Java NIO verwenden. Da braucht man nicht für jeden Client einen Thread. Oder noch besser gleich soetwas wie Apache MINA benutzen...

Bei allem anderen "dispatcht" sich der Threaddispatcher zu tode ...

- Alex
 

Ebenius

Top Contributor
tuxedo hat gesagt.:
Bei allem anderen "dispatcht" sich der Threaddispatcher zu tode ...

Das hängt doch nur davon ab, wie oft die Threads aktiviert werden. Normaler weise werden die meisten Threads in einem wait hängen, bis mal Daten über den Strom huschen. Damit kann man eigentlich gut leben.

Aber wenn man mit NIO oder MINA sowas besser lösen kann. Gern. Hab ich normaler Weise nicht so viel (NIO) bzw. nichts (MINA) zu tun.

Ebenius
 
T

tuxedo

Gast
Ich weiß ja nicht was der Server zu machen/bearbeiten hat. Aber ich tippe mal darauf dass eine 0815 Serveranwendung die Clients bedienen muss, bei >=1000 Clients schon im Schnitt einige hundert Clients irgendwie aktiv sind.

Zumindest würde ich nicht das "Risiko" eingehen wollen. Klar, die Chefs/Produktmanager meinen am Anfang oft "nur was kleines, wird nix großes". BIs sie sehen dass sich's gut verkauft und dann doch "was großes" wird. Und dann passt die Architektur vorne und hinten nicht.

Die Einarbeitungszeit in MINA ist nicht allzu hoch wenn man sich die Samples anschaut. Und man hat noch den Vorteil dass man gleich bequem und sehr abstrakt entwicklen kann statt sich um alles Grundlegende selbst zu kümmern.

gut, muss nicht MINA sein. Jedem das seine. Aber zumindest anschauen würd' ich's mal bevor ich anfange mit "normalem" IO einen Server für >=1000 Clients zu entwickeln.

- Alex
 
T

tuxedo

Gast
Naja, nacktes NIO ist nicht einfach zu verwenden. Hab selbst einge Wochen gebraucht bis ich ein stabiles und brauchbares Grundgerüst hatte.
Bin dann aber doch zu MINA gewechselt weil's einfach genial zu verwenden ist und prima erweitert und für die eigenen bedürfnisse zurechtgeschnitten werden kann.

- Alex
 
T

tuxedo

Gast
Jepp. xSocket abstrahiert einfach nur NIO. MINA geht da einen Schritt weiter und bietet schon Features für Protokolle und unterschiedliche "Transports".

- Alex
 

elinmerl

Mitglied
Hallo,

nachdem ich mich einen Tag mit NIO beschäftigt habe, habe ich mir doch noch MINA angeschaut. UNd ich muss sagen: Zum Glück! Im Vergleich zu reinem NIO ist MINA recht einfach zu verstehen und anzuwenden.
Danke noch einmal für diesen Hinweis!

Andreas
 
T

tuxedo

Gast
Sag ich doch.

xSocket ist aber auch okay wenn man sehr low-level auf der NIO-Schicht arbeiten will.

Parallel zu MINA gibts noch NETTY. Kann man sich auch mal anschauen. Sind aber seeeehr verwand (haben den gleichen Ursprung).

- Alex
 
Status
Nicht offen für weitere Antworten.
Ähnliche Java Themen
  Titel Forum Antworten Datum
H Applet soll XML-File auf Server speichern Netzwerkprogrammierung 6
C NTP-Applikation soll mit "fertigem" NTP-Server kommunizieren Netzwerkprogrammierung 2
J Applet soll Daten auf Server ablegen - einfachster Weg fuer n00bs? Netzwerkprogrammierung 4
H Server soll Daten schicken, aber wie? Netzwerkprogrammierung 47
Lazybone Client soll auf Knopfdruck vom Server warten Netzwerkprogrammierung 4
J Server soll Zugriff auf Java Programm ermöglichen Netzwerkprogrammierung 3
F Wie soll ich meinen Server aufbauen? Netzwerkprogrammierung 4
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
izoards Mehrere TCP Verbindungen auf einen Server [alles Local] Netzwerkprogrammierung 2
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
K C# Server - Android Client Netzwerkprogrammierung 0
J Framework mehrere Clients/ Server-Broadcast/oracle XE/ XML Netzwerkprogrammierung 1
D Mit Server Daten austauschen Netzwerkprogrammierung 4
V Server / mehrere Clients / MySQL / Konzept Netzwerkprogrammierung 2

Ähnliche Java Themen

Neue Themen


Oben