AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Netzwerke Delphi TIdTCPClient gibt nach Disconnect Socket nicht frei
Thema durchsuchen
Ansicht
Themen-Optionen

TIdTCPClient gibt nach Disconnect Socket nicht frei

Ein Thema von s.h.a.r.k · begonnen am 10. Sep 2008 · letzter Beitrag vom 10. Sep 2008
Antwort Antwort
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#1

TIdTCPClient gibt nach Disconnect Socket nicht frei

  Alt 10. Sep 2008, 14:53
hallo zusammen

ich habe gerade das folgende problem: und zwar nutze ich die indy-komponenten tidtcpserver und tidtcpclient, um einen datenaustausch zu implementieren. nun ist es so, dass ich beim onlclick auf einen button die verbindung vom client zum server aufbaue und dann nicht mehr disconnecte, bis ich wieder auf den button klicke oder das programm beendet wird. alleine hier tritt schon die frage auf, ob das irgendwas macht? weil ich schon gelesen habe, dass einigebei jeder anfrage erst connecten und dann sofort wieder disconnecten. find ich sehr seltsam

das eigentliche problem besteht beim disconnect: da wird der socket nicht freigegeben, obwohl ich eben dem client zum disconnect hinweise. sitze gerade nur am anderen rechner, aber ich meine, ich mache tcpclient.disconnect();, oder dergleichen. ich dachte das reicht an sich? aber selbst wenn ich die anwendung schließe ist der socket noch belegt, wie lange genau kann ich nicht sagen...

wieso wird der socket nicht freigegeben? selbst nach dem beenden des programms? bzw. was muss ich machen, dass der socket wieder freigegeben wird?!

mit freundlichen grüßen
der hai
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
Klaus01

Registriert seit: 30. Nov 2005
Ort: München
5.755 Beiträge
 
Delphi 10.4 Sydney
 
#2

Re: TIdTCPClient gibt nach Disconnect Socket nicht frei

  Alt 10. Sep 2008, 15:01
Hallo,

wenn Du in einem cmd Box einmal netstat -nap ausführst
wirst Du sehen das der Zustand des Sockets/Ports nicht mehr ESTABLISHED ist.
Er wird im WAIT_TIME Status sein.
Das OS sorgt dafür das diese Sockets/Ports wieder entfernt werden.
Nach welcher Zeit das passiert - keine Ahnung.

Hier noch ein nettes Diagramm, dass die Stati einer TCP Verbindung aufzeigt.

Grüße
Klaus
Klaus
  Mit Zitat antworten Zitat
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#3

Re: TIdTCPClient gibt nach Disconnect Socket nicht frei

  Alt 10. Sep 2008, 15:17
ja genau, da steht dann wartend dran! das stimmt. ich schaue eben auch mit dem netstat-befehl auch nach, welche verbindungen "online" (im weitesten sinne) onlnie sind.

wie komme ich aber um diesen "fehler" drum herum, denn wenn man nun die anwendung zwei mal mit dem gleichen port ausführt, dann klappt es das zweite mal nun mal nicht mehr und das ist nicht wirklich toll! was ich auch schon gemacht habe ist die portnummer weggelassen. dann ist es halt so, dass er sich eine passende frei nummer sucht, aber ich mag es einfach definiert haben, sodass ich dies auch in der dokumentation nieder schreiben kann.

ich hoffe, dass es doch einen passende lösung dafür gibt!?
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
Klaus01

Registriert seit: 30. Nov 2005
Ort: München
5.755 Beiträge
 
Delphi 10.4 Sydney
 
#4

Re: TIdTCPClient gibt nach Disconnect Socket nicht frei

  Alt 10. Sep 2008, 15:22
hier wird geschrieben ( am Ende der Seite), das man den Socket mit so_reuse erstellen kann
um ihn anschließend gleich wieder zu verwenden.

Aber mal eine Frage, was zwingt Dich denn dazu die ClientSeite immer auf einen festen Port zu binden?

Grüße
Klaus
Klaus
  Mit Zitat antworten Zitat
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#5

Re: TIdTCPClient gibt nach Disconnect Socket nicht frei

  Alt 10. Sep 2008, 17:33
da magst du echt recht habe. kommt nur drauf an, was das alles für konsequenzen hat. die software läuft in einem unternehmens-netzwerk und ich gehe einfach davon aus, dass es für eine dokumentation besser ist, dass der port, auf dem eine anwendung läuft, fest dokumentiert ist. ich finde, dass es sich ein wenig "wischi-waschi" anhört, wenn ich sage, dass sich der port selbst einstellt, wobei das eben mehr flexibilität schafft.

an dieser stelle wäre es allerdings interessant zu wissen, wie sich der port dann "selbst" einstellt, bzw. wie ein freier port ermittelt wird!?
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  Mit Zitat antworten Zitat
Klaus01

Registriert seit: 30. Nov 2005
Ort: München
5.755 Beiträge
 
Delphi 10.4 Sydney
 
#6

Re: TIdTCPClient gibt nach Disconnect Socket nicht frei

  Alt 10. Sep 2008, 18:02
nun, der Server läuft auf einem definierten Port.
Den siehst Du mit netstat -a im Status LISTENING.
Dieser Port wird auch direkt wieder freigemacht sobald der Serverdienst beendet wurde.

Der Client sendet nun zu diesen ServerPort ein SYNC.
Der Port von dem der Client sendet ist mehr oder weniger beliebig.
Der Server antwortet nun mit einem Sync-Ack auf diesen Port, der Sever weiß von welchem
Port der Client gesendet hat, denn er hat ja das SYNC Packet empfangen.

Sollte eine Firewall im Kommunikationsweg sein, so muss diese von ausserhalb
auf dem definierten Serverport durchlässig sein. Wenn Ports von der Innenseite
angefragt werden, so werden diese in der Regel durchgelassen.

Delphi-Quellcode:
   angennommen der Server lauscht auf Port 50000
   aussen FW innen
   Client ->SYNC,50000 FW -> SYNC,50000 -> Server
   Client <-SYNC,ACK FW <- SYNC,ACK <- Server
Grüße
Klaus
Klaus
  Mit Zitat antworten Zitat
Benutzerbild von s.h.a.r.k
s.h.a.r.k

Registriert seit: 26. Mai 2004
3.159 Beiträge
 
#7

Re: TIdTCPClient gibt nach Disconnect Socket nicht frei

  Alt 10. Sep 2008, 22:00
ah, vielen dank trägt echt sehr zu meinem verständnis bei. jetzt hat sich wohl einiges erübrigt
»Remember, the future maintainer is the person you should be writing code for, not the compiler.« (Nick Hodges)
  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 18:11 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