AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Netzwerke Delphi TCP/IP-Telegrammverkehr mit Anlagensteuerung/SPS
Thema durchsuchen
Ansicht
Themen-Optionen

TCP/IP-Telegrammverkehr mit Anlagensteuerung/SPS

Offene Frage von "divBy0"
Ein Thema von Nico B. · begonnen am 19. Feb 2014 · letzter Beitrag vom 22. Feb 2014
Antwort Antwort
Nico B.

Registriert seit: 16. Okt 2006
Ort: Riesa
67 Beiträge
 
Delphi XE7 Enterprise
 
#1

AW: TCP/IP-Telegrammverkehr mit Anlagensteuerung/SPS

  Alt 21. Feb 2014, 09:42
Hallo Leute,
also erst mal... Ich find´s ja total klasse, hier so gut informierte Leute erwischt zu haben. Da sollte es ja kein Problem mein bisl Kleinkram zu lösen.

Ich für meinen Teil hab (nachdem ich zunächst ein wenig mit sirius Quellcode experimentiert habe und mir anschließend das libnodave-Beispiel angeschaut habe) auch langsam das Gefühl das libnodave schon ein wenig zu weit geht.
Ich will nicht auf Datenbausteine einer SPS zugreifen.
Mir reicht schon ein einfacher TCP/IP-Telegrammverkehr.

Mein Frage ist nun, wenn ich mit dem Quellcode von sirius weitermache, komme ich dann auch zum Ziel?
Mit TClientSocket und TServerSocket kann ich ja verschiedene Daten senden.

Könnt ihr mal sagen, ob das funktionieren würde?

Codebeispiel für das Versenden eines Telegramms von Delphi zur SPS:
Code:
FClient:=TClientSocket.Create(self);
try
  FClient.Adress:='0.8.1.5'; //IP der SPS
  FClient.Port:=5000;       //Port über den kommuniziert werden soll
  FClient.ClientType:=ctNonBlocking;
  FClient.Open;
  FClient.Socket.SendText('Hallo SPS');
finally
  FClient.Free;
end;
Codebeispiel für das Empfangen eines Telgramms von der SPS durch Delphi:
Code:
//Serververbindung herstellen
FServer:=TServerSocket.Create(self);
try
  FServer.Port:=5001;       //Port über den kommuniziert werden soll
  FServer.OnClientRead:=ServerRead;
  FServer.Open;
except
  FServer.Free;
end;

//Telgramm empfangen
procedure ServerRead(Sender: TObject; Socket: TCustomWinSocket);
begin
  Memo1.Lines.Add(Socket.ReceiveText);
end;

//TServerSocket vor Beenden im OnDestroy der Form freigeben
FServer.Free;
Vor allem bin ich mir ja unsicher, ob SendText die richtige Methode ist.
Vielleicht müsste/sollte ich besser SendStream oder SendBuf nehmen.
Wie ist eure Meinung dazu?
Nico Bäger
  Mit Zitat antworten Zitat
Buddelfish
(Gast)

n/a Beiträge
 
#2

AW: TCP/IP-Telegrammverkehr mit Anlagensteuerung/SPS

  Alt 21. Feb 2014, 12:11
Ich würde die per 'Close' noch explizit schließen. Aber grundsätzlich musst Du das Unit of Work Konzept hier nicht anwenden, d.h. Du schmeißt den Client auf dein Formular, öffnest ihn und wenn Du was schicken willst, schickst Du einfach. Wenn die Verbindung offen bleiben soll, dann würde ich mir über ein 'Keep Alive' Gedanken machen, d.h. der Client schickt an den Servcer 1x pro Sekunde (oder seltener) ein 'X' und der Server antwortet mit einem 'Y'. Kommt beim Client kein 'Y' stimmt was mit der Verbindung nicht und kommt nicht alle x Sekunden am Server kein 'X' stimmt auch was mit der Verbindung nicht. Beide können die Verbindung abbrechen und sich dann wieder verbinden.

Das mit dem 'X' und 'Y' ist nur exemplarisch, hier kann man noch eine laufende Nummer, Statusinformationen etc. reinpacken. Es soll halt nur kurz und in regelmäßigen Abständen passieren.
  Mit Zitat antworten Zitat
Nico B.

Registriert seit: 16. Okt 2006
Ort: Riesa
67 Beiträge
 
Delphi XE7 Enterprise
 
#3

AW: TCP/IP-Telegrammverkehr mit Anlagensteuerung/SPS

  Alt 21. Feb 2014, 12:31
Okay, du meinst also so eine Art Watchdog.
Das würde ich auch definitiv implementieren.
Die Verbindung möchte ich über längere Zeit offen halten, da wäre so etwas sicher angebracht.

Jetzt frage ich mich aber noch, ob SendText wirklich das richtige ist bei der Kommunikation mit einer SPS...
Nico Bäger
  Mit Zitat antworten Zitat
Benutzerbild von sirius
sirius

Registriert seit: 3. Jan 2007
Ort: Dresden
3.443 Beiträge
 
Delphi 7 Enterprise
 
#4

AW: TCP/IP-Telegrammverkehr mit Anlagensteuerung/SPS

  Alt 21. Feb 2014, 13:42
1. Ich hoffe du hast keine 0815 IP genommen Und der Port ist auch entsprechend der Doku geändert wurden.

Ich habe noch nie mit einer SPS kommuniziert, aber mit verschiedenen anderen Geräten. Meistens weisen die Geräte auch ganz simple ASCII Protokolle auf, da ist ein SendText genug. Schreib doch mal ein bisschen vom Protokoll auf, was Du so senden musst.
Und wozu brauchst Du einen Server? Verbindet sich die SPS zurück?
Dieser Beitrag ist für Jugendliche unter 18 Jahren nicht geeignet.
  Mit Zitat antworten Zitat
Benutzerbild von divBy0
divBy0

Registriert seit: 4. Mär 2007
Ort: Sponheim
1.021 Beiträge
 
Delphi XE2 Professional
 
#5

AW: TCP/IP-Telegrammverkehr mit Anlagensteuerung/SPS

  Alt 22. Feb 2014, 01:26
Warum nutzt du nicht die Indykomponenten?

Mit IdTCPClient.Socket.Write() kannst du einfach alles versenden was du brauchst, aber du musst dran denken, dass die Bytereihenfolge getauscht werden muss.

Bei der SPS gibt es kein Protokoll, du sendest einfach ein Array of Bytes mit deinen Inhalten. Die SPS empfängt und schreibt in die angegebenen Datenbausteine.

Einige Grundkenntnisse über die Datentypen in der SPS sollten vorhanden sein.
Marc
9 von 10 Stimmen in meinem Kopf sagen ich bin nicht verrückt, die 10. summt die Melodie von Tetris... | Wenn das die Lösung ist, dann hätte ich gerne mein Problem zurück! | engbarth.es

Geändert von divBy0 (22. Feb 2014 um 02:20 Uhr)
  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:46 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