AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Win32/Win64 API (native code) Socket-Kommunikation mit anderem Prozess aufbauen - Wie finde ich den überhaupt?
Thema durchsuchen
Ansicht
Themen-Optionen

Socket-Kommunikation mit anderem Prozess aufbauen - Wie finde ich den überhaupt?

Ein Thema von Der schöne Günther · begonnen am 10. Mai 2013 · letzter Beitrag vom 10. Mai 2013
Antwort Antwort
Der schöne Günther

Registriert seit: 6. Mär 2013
6.176 Beiträge
 
Delphi 10 Seattle Enterprise
 
#1

Socket-Kommunikation mit anderem Prozess aufbauen - Wie finde ich den überhaupt?

  Alt 10. Mai 2013, 12:23
Ja, dumme Frage. Erst hier über die wildesten Middleware-Frameworks philosophiert und jetzt noch nichtmal Socket-Kommunikation zwischen eigenen Prozessen auf die Reihe bekommen.

Ich dachte an TCP/IP zwischen meinen Prozessen. Ich habe ein Hauptprogramm und eine variable Anzahl von auf Anweisungen von ihm lauschende Plug-Ins. Diese Plug-Ins werden auf der gleichen Maschine übrigens aller Sittenhaftigkeit nach Kind-Prozesse des Hauptprogramms sein.

Jeder würde wahrscheinlich das Hauptprogramm zum Server machen und die Plug-Ins verbinden sich mit ihm. Ich finde diesen Ansatz nicht passend, die Plug-Ins sollen selbst der Server sein damit ich sie später eventuell auch mal von anderen Anwendungen (evtl. sogar auf anderen Computern) ansprechen kann - Siehe Skizze im Anhang.


Die Aufgabe: Der Kindprozess muss nun den Hauptprozess finden und ihm sagen "Hallo - Hier die Adresse unter der du mich in Zukunft erreichst falls du was zu sagen hast".

Ironischerweise muss man jetzt IPC betreiben um IPC betreiben zu können - Ich möchte nicht festlegen, auf welchen konkreten Portnummern gefunkt werden soll - Das gibt doch nur wieder Ärger falls auf der Maschine dann später noch Drittanbieter-Kram installiert wird.

Ich dachte hier an eine Named Pipe welche das Hauptprogramm bereithält für "Hallo, ich bin ein Plugin, erreichen kannst du mich in Zukunft auf diesem Socket". Broadcasts über Sockets fällt flach, ist ja kein UDP.


Ist das eine halbwegs hieb- und stichfeste Idee? Über Authentifizierung und Abhörsicherheit in der Datenübertragung haben wir uns noch keine Gedanken gemacht, Sessions werden auch nicht gebraucht.
Miniaturansicht angehängter Grafiken
new-sequence-diagram_.png  

Geändert von Der schöne Günther (10. Mai 2013 um 12:36 Uhr)
  Mit Zitat antworten Zitat
mjustin

Registriert seit: 14. Apr 2008
3.006 Beiträge
 
Delphi 2009 Professional
 
#2

AW: Socket-Kommunikation mit anderem Prozess aufbauen - Wie finde ich den überhaupt?

  Alt 10. Mai 2013, 13:15
die Plug-Ins sollen selbst der Server sein
Dann müssen sie natürlich auf unterschiedlichen Ports lauschen. Und woher wissen sie welcher frei ist? Theoretisch könnten sie beim Start ab einem bestimmten Port beginnen und bei Kollisionen die Portnummer erhöhen, oder einen zufälligen Port in einem bestimmten Bereich öffnen.

Ich würde bei den Plugins keinen Serverport öffnen. Wozu ist das notwendig? Man kann auch bei einem Client, der sich mit einem Server verbindet, problemlos Pakete sowohl vom Client an den Server oder vom Server an den Client senden. TCP/IP Sockets sind immer auch bidirektional (Peer-to-Peer) benutzbar.

Wenn später mal andere Anwendungen auf die Plugins zugreifen müssen, können sie das über den Hauptprozess als Zwischenschritt tun.
Michael Justin
  Mit Zitat antworten Zitat
Benutzerbild von Phoenix
Phoenix
(Moderator)

Registriert seit: 25. Jun 2002
Ort: Hausach
7.641 Beiträge
 
#3

AW: Socket-Kommunikation mit anderem Prozess aufbauen - Wie finde ich den überhaupt?

  Alt 10. Mai 2013, 13:36
Siehe hier: http://www.delphipraxis.net/1209879-post9.html
Sebastian Gingter
Phoenix - 不死鳥, Microsoft MVP, Rettungshundeführer
Über mich: Sebastian Gingter @ Thinktecture Mein Blog: https://gingter.org
  Mit Zitat antworten Zitat
Der schöne Günther

Registriert seit: 6. Mär 2013
6.176 Beiträge
 
Delphi 10 Seattle Enterprise
 
#4

AW: Socket-Kommunikation mit anderem Prozess aufbauen - Wie finde ich den überhaupt?

  Alt 10. Mai 2013, 13:53
Danke für den Hinweis auf SLP - Aber ich glaube das schießt über das Ziel hinaus. Mir ging es mehr darum, nicht noch einmal eine zweite IPC-Methode aufzusetzen, um die erste überhaupt erst möglich zu machen. SLP sieht nach einer tollen Sache aus, aber damit sich zwei verwandte Prozesse unterhalten wohl zwei Nummern zu groß.

Zitat:
Ich würde bei den Plugins keinen Serverport öffnen. Wozu ist das notwendig? [...] Wenn später mal andere Anwendungen auf die Plugins zugreifen müssen, können sie das über den Hauptprozess als Zwischenschritt tun.
Ja, das wäre die große Alternative. Allerdings verbaue ich mir damit die Option, die Anwendung in Zukunft evtl. doch auf mehrere Systeme zu verteilen. Es sei denn, ich pflanze doch wieder jedem Modul etwas ein, selbstständig im Netzwerk zu wühlen und zu versuchen, das Hauptprogramm zu finden. Das ist zugegebenermaßen schon sehr elegant. Aber wenn der Kunde merkt, dass hier nicht eindeutig nachzuvollziehender Netzwerkverkehr entsteht schrillen oft alle Alarmglocken

Mein Plan zusammengefasst noch einmal folgendermaßen:
  1. Hauptprogramm wird gestartet
  2. Hauptprogramm startet Plug-Ins als Kindprozesse
  3. Kindprozesse suchen sich einen Port zum Lauschen und teilen dem Elternprozess diesen Port irgendwie mit
  4. Wenn das Hauptprogramm etwas mit einem Plug-In anstellen will, schickt es ihm auf der ihm nun bekannten Adresse eine Nachricht

Für Punkt 3) muss ich mich noch schlau machen, hier reichen wahrscheinlich schon anonyme (lokale) Pipes.
  Mit Zitat antworten Zitat
Antwort Antwort


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 07:50 Uhr.
Powered by vBulletin® Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
LinkBacks Enabled by vBSEO © 2011, Crawlability, Inc.
Delphi-PRAXiS (c) 2002 - 2023 by Daniel R. Wolf, 2024 by Thomas Breitkreuz