AGB  ·  Datenschutz  ·  Impressum  







Anmelden
Nützliche Links
Registrieren
Zurück Delphi-PRAXiS Programmierung allgemein Netzwerke Indy10: Können Datenpakete überholt werden?
Thema durchsuchen
Ansicht
Themen-Optionen

Indy10: Können Datenpakete überholt werden?

Ein Thema von eegoar · begonnen am 11. Feb 2014 · letzter Beitrag vom 11. Feb 2014
Antwort Antwort
eegoar

Registriert seit: 7. Aug 2008
6 Beiträge
 
#1

Indy10: Können Datenpakete überholt werden?

  Alt 11. Feb 2014, 16:17
Hallo.

Für ein etwas umfangreicheres Multiplayerspiel habe ich folgendes realisiert:

Es gibt einen Host (der Client und Server enthält) und bis zu 7 weitere Clienten.
30 mal pro Sekunde sendet der Host an alle Clienten (auch sich selbst) ein Datenpaket. Dieses Datenpaket besteht entweder aus den Informationen A oder Informationen B. Es wird korrekt auf den Clienten ermittelt, ob das Paket A oder B ist.
Jedes mal, wenn die Clienten Paket A oder B erhalten, so wird ein bestimmter Rechenschritt ausgeführt. Das bedeutet, dass alle Clienten gleich viele gleiche Rechenschritte machen und dementsprechend alle in derselben Geschwindigkeit laufen (die der Host vorgibt).
Datenpaket A enthält nur die Info, dass ein Rechenschritt gemacht wird. Paket B enthält auch die Information, dass einer, mehrere oder alle Clienten eine Aktion (z.B. Mausklick) ausgeführt haben.
Klickt der Client mit der Maus, so sendet er ein Paket C an den Server, aber im Clienten selber wird der Mausklick noch nicht verrechnet. Erst der Host sendet mit Paket B an alle Clienten, dass ein Client einen entsprechenden Mausklick ausgeführt hat.

Am Ende sollen eben alle Clienten exakt dieselben Berechnungen und Darstellungen haben, wie die anderen Clienten.

Nur wenn ich mit 8 Spielern teste, so gibt es nach ein paar Minuten kleine Unregelmäßigkeiten.
Alle Clienten zeigen an, dass sie dieselbe Anzahl Pakete von A und B erhalten haben. Die Zufallswerte sind in einer festen Reihenfolge, die ich vorher definiert habe. Alle Clienten haben IMMER dieselben Zufallswerte zu einem bestimmten Zeitpunkt (Rechenschritt), ich schließe aus, dass es daran liegt.

Meine Vermutung ist, dass irgendwo bei einem Clienten ein Paket A ein Paket B überholt hat. Der Server sendet über TCP, das Paket A ist nur etwa 1/30 der Größe von B. Ist das möglich?
Wenn ja, wie realisiere ich, dass so etwas nicht passiert, also dass die Reihenfolge der Datenpakete überall eingehalten wird?

mfG, eegoar
  Mit Zitat antworten Zitat
Benutzerbild von Neutral General
Neutral General

Registriert seit: 16. Jan 2004
Ort: Bendorf
5.219 Beiträge
 
Delphi 10.2 Tokyo Professional
 
#2

AW: Indy10: Können Datenpakete überholt werden?

  Alt 11. Feb 2014, 16:30
Hallo,

Wenn du UDP benutzt dann kann das passieren.
Bei TCP wird die Reihenfolge der Pakete beibehalten.
Da kann B eigentlich nicht vor A ankommen.
(Kann schon, aber dann wird auf A gewartet und erst A zurückgegeben und dann B)
Michael
"Programmers talk about software development on weekends, vacations, and over meals not because they lack imagination,
but because their imagination reveals worlds that others cannot see."
  Mit Zitat antworten Zitat
hathor
(Gast)

n/a Beiträge
 
#3

AW: Indy10: Können Datenpakete überholt werden?

  Alt 11. Feb 2014, 16:40
Zitat:
"Beispiel einer TCP-/IP-Datenübertragung

Der Sender schickt sein erstes TCP-Segment mit einer Sequenznummer SEQ=1 (variiert) und einer Nutzdatenlänge von 1460 Byte an den Empfänger. Der Empfänger bestätigt es mit einem TCP-Header ohne Daten mit ACK=1461 und fordert damit das zweite TCP-Segment ab dem Byte Nummer 1461 beim Sender an. Dieser schickt es dann mit einem TCP-Segment und SEQ=1461 an den Empfänger. Dieser bestätigt es wieder mit einem ACK=2921 und so weiter. Der Empfänger braucht nicht jedes TCP-Segment zu bestätigen, wenn diese zusammenhängend sind. Empfängt er die TCP-Segmente 1–5, so braucht er nur das letzte TCP-Segment zu bestätigen.
Fehlt zum Beispiel das TCP-Segment 3, weil es verlorengegangen ist, so kann er nur die 1 und die 2 bestätigen, 4 und 5 jedoch noch nicht. Da der Sender keine Bestätigung für die 3 bekommt, läuft sein Timer ab, und er verschickt die 3 noch einmal.

Kommt die 3 beim Empfänger an, so bestätigt er alle fünf TCP-Segmente. Der Sender startet für jedes TCP-Segment, welches er auf die Reise schickt, einen Retransmission Timer."
http://de.wikipedia.org/wiki/Transmi...ntrol_Protocol
  Mit Zitat antworten Zitat
mjustin

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

AW: Indy10: Können Datenpakete überholt werden?

  Alt 11. Feb 2014, 16:51
Klickt der Client mit der Maus, so sendet er ein Paket C an den Server
Nur zum besseren Verständnis: wieviele Threads verwendet der Client? So wie es beschrieben ist tippe ich auf einen Empfangsthread zum Warten auf A und B Pakete und einen Thread in dem das Paket C gesendet wird. Benutzt der Client zum Lesen und Schreiben die gleiche Connection (Socket) Komponente, oder wird ein TIdTCPClient nur zum Lesen und einer nur zum Schreiben eingesetzt?
Michael Justin
  Mit Zitat antworten Zitat
eegoar

Registriert seit: 7. Aug 2008
6 Beiträge
 
#5

AW: Indy10: Können Datenpakete überholt werden?

  Alt 11. Feb 2014, 23:35
Danke für die Antworten.

Ich habe das Problem gelöst. Es wurden keine Pakete überholt oder nicht gesendet, sondern ich habe in einer bestimmten Prozedur Zufallsvariablen abgefragt, die davon abhängig waren, was der Client für ein Menü geöffnet hat und welche Menübilder zu sehen waren.
Da die Clienten verschiedene Menüs öffnen können und dementsprechend verschiedene Bilder auf dem Programm sehen, waren plötzlich überall verschiedene Zufallswerte vorhanden, die natürlich in dem Spiel bei jedem Clienten alles anders aussehen lassen haben.

Also lag es doch daran, welche Zufallswerte erzeugt werden
  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 03:34 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