AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Programmieren allgemein Echtzeitbenachrichtigungen - Welche Technik?

Echtzeitbenachrichtigungen - Welche Technik?

Ein Thema von TheMiller · begonnen am 30. Nov 2015 · letzter Beitrag vom 3. Dez 2015
Antwort Antwort
Benutzerbild von himitsu
himitsu
Online

Registriert seit: 11. Okt 2003
Ort: Elbflorenz
44.560 Beiträge
 
Delphi 12 Athens
 
#1

AW: Echtzeitbenachrichtigungen - Welche Technik?

  Alt 30. Nov 2015, 10:53
Wenn ich jetzt vom Embarcadero-Vertrieb wäre, dann
http://edn.embarcadero.com/article/41374

Im neuen coolen EMS gibt es sowas bestimmt auch.


Auch einige DBMS haben Callbacks/Alerter, wo z.B. aus Triggern eine Nachricht an einen/alle Clienten verwendet werden kann.
Ein Therapeut entspricht 1024 Gigapeut.

Geändert von himitsu (30. Nov 2015 um 11:01 Uhr)
  Mit Zitat antworten Zitat
Benutzerbild von BUG
BUG

Registriert seit: 4. Dez 2003
Ort: Cottbus
2.094 Beiträge
 
#2

AW: Echtzeitbenachrichtigungen - Welche Technik?

  Alt 30. Nov 2015, 13:44
Node.js, Websockets, .... Willst du jetzt die Servertechnologie festlegen oder das Protokoll
Wenn du schon eine Rest-API hast, würde ich mir Long-Polling angucken. Vielleicht kannst du das mit dem bestehendem Backend gut umsetzten.
  Mit Zitat antworten Zitat
Benutzerbild von Olli73
Olli73

Registriert seit: 25. Apr 2008
Ort: Neunkirchen
793 Beiträge
 
#3

AW: Echtzeitbenachrichtigungen - Welche Technik?

  Alt 30. Nov 2015, 15:01
Wenn du schon eine Rest-API hast, würde ich mir Long-Polling angucken.
Das hätte ich jetzt auch vorgeschlagen.

Websockets sind zwar "moderner" und haben weniger Overhead, aber in diesem Fall sollte Long Polling ausreichen.
  Mit Zitat antworten Zitat
Benutzerbild von Valle
Valle

Registriert seit: 26. Dez 2005
Ort: Karlsruhe
1.223 Beiträge
 
#4

AW: Echtzeitbenachrichtigungen - Welche Technik?

  Alt 30. Nov 2015, 15:05
Wobei es für mich fraglich ist, warum man bei der Implementation eines neuen Features denn auf solch einen "Workaround" wie Long-Polling zurückgreifen will, wenn es doch mittlerweile moderne Techniken gibt, die für deinen Einsatzzweck auch wirklich gedacht sind. Ich würde das vorher gut abwägen. Wenn Long-Polling wirklich viel schneller und einfacher implementiert ist, dann ist das durchaus ein Argument. Falls nicht, würde ich diesen Hack im Jahr 2015 nicht mehr neu programmieren.
Valentin Voigt
BOFH excuse #423: „It's not RFC-822 compliant.“
Mein total langweiliger Blog
  Mit Zitat antworten Zitat
Benutzerbild von TheMiller
TheMiller

Registriert seit: 19. Mai 2003
Ort: Gründau
2.480 Beiträge
 
Delphi XE7 Architect
 
#5

AW: Echtzeitbenachrichtigungen - Welche Technik?

  Alt 30. Nov 2015, 15:19
Danke schonmal für die Antworten.

Longpolling hab ich eigentlich tatsächlich deswegen schon ausgeschlossen, aber lasse mich ja auch gerne von anderen Argumenten wieder überzeugen.

Es muss ja zudem auch noch eine Lösung sein, mit der Sprachenunabhängig kommuniziert werden kann (w32-Anwendung mit Webseite). Ich hab mal quergelesen, ob das mit Websockets wirklich funktioniert.

Was stehen denn generell für Techniken hinsichtlich (bidirektionaler) Echtzeitbenachrichtigung zur Verfügung? Auf Anhieb fallen mir diese Techniken ein:

* MessageBroker (bidirektional)
* Websockets (bidirektional)
* LongPolling (unidirektional)
* Polling (unidirektional)

Wenn wir über eine echte Webseite sprechen, welche von mir aus 500-1000 User gleichzeitig hat und ebenfalls solche Nachrichten getauscht werden sollen, fällt LongPolling schon raus, sodass man dann zu MBs oder WS greifen sollte, nicht wahr?

Wichtig ist halt in beiden Fällen (lokale Webseite bis 10 User / "echte" Webseite mit unbegrenzten Usern), dass die Nachrichtentechnik stets auch im Windows-Programm funktioniert. Damit meine ich, dass im Desktop-Client Daten sofort nachgeladen werden, wenn sich im Web etwas geändert hat.

Habe sowas natürlich noch nie umgesetzt, daher frage ich so nach. Mache mir aber schon seit längerem Gedanken, jetzt seit kurzem auch genauere.
Bisheriger Nutzername "DJ-SPM"
  Mit Zitat antworten Zitat
Benutzerbild von BUG
BUG

Registriert seit: 4. Dez 2003
Ort: Cottbus
2.094 Beiträge
 
#6

AW: Echtzeitbenachrichtigungen - Welche Technik?

  Alt 30. Nov 2015, 18:52
Es war halt der Gedanke, dass du auf Client-Seite vielleicht besser zu einer "guten" Long-Polling Variante basierend auf HTTP kommst als zu einer hingewurschtelten Websocket-Lösung basierend auf TCP. Keine Ahnung was Delphi da mittlerweile anbietet
Auf Serverseite muss dir bewusst sein, dass Websockets kein normales HTTP sind, und du damit eventuell Probleme mit Proxies (usw.) haben kannst.

Message-Broker fallen ein bisschen aus deiner Aufzählung von Protokollen heraus. Sie sind eher Middleware und können selbst unterschiedliche Protokolle (OpenWire, STOMP, usw.) anbieten.
  Mit Zitat antworten Zitat
Benutzerbild von Valle
Valle

Registriert seit: 26. Dez 2005
Ort: Karlsruhe
1.223 Beiträge
 
#7

AW: Echtzeitbenachrichtigungen - Welche Technik?

  Alt 30. Nov 2015, 21:48
Es war halt der Gedanke, dass du auf Client-Seite vielleicht besser zu einer "guten" Long-Polling Variante basierend auf HTTP kommst als zu einer hingewurschtelten Websocket-Lösung basierend auf TCP. Keine Ahnung was Delphi da mittlerweile anbietet
Da stimme ich dir allerdings zu.

Ich hatte gerade dummerweise nur Browserlösungen im Kopf. Da klappt das gut. Wenn's für Delphi da nix gibt, dann doch lieber ne andere Lösung suchen.
Valentin Voigt
BOFH excuse #423: „It's not RFC-822 compliant.“
Mein total langweiliger Blog
  Mit Zitat antworten Zitat
Antwort Antwort

Themen-Optionen Thema durchsuchen
Thema durchsuchen:

Erweiterte Suche
Ansicht

Forumregeln

Es ist dir nicht erlaubt, neue Themen zu verfassen.
Es ist dir nicht erlaubt, auf Beiträge zu antworten.
Es ist dir nicht erlaubt, Anhänge hochzuladen.
Es ist dir nicht erlaubt, deine Beiträge zu bearbeiten.

BB-Code ist an.
Smileys sind an.
[IMG] Code ist an.
HTML-Code ist aus.
Trackbacks are an
Pingbacks are an
Refbacks are aus

Gehe zu:

Impressum · AGB · Datenschutz · Nach oben
Alle Zeitangaben in WEZ +1. Es ist jetzt 18:33 Uhr.
Powered by vBulletin® Copyright ©2000 - 2025, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024-2025 by Thomas Breitkreuz