mirror of
https://github.com/genxium/DelayNoMore
synced 2025-01-13 22:41:30 +00:00
Updated documentation for the plan of UDP secondary session.
This commit is contained in:
parent
7a0127b17d
commit
ff48b47ecc
@ -69,4 +69,10 @@ To summarize, if UDP is used we need
|
|||||||
When using UDP, it's also necessary to verify authorization of each incoming packet, e.g. by simple time limited symmetric key, due to being connectionless.
|
When using UDP, it's also necessary to verify authorization of each incoming packet, e.g. by simple time limited symmetric key, due to being connectionless.
|
||||||
|
|
||||||
## Why not hybrid?
|
## Why not hybrid?
|
||||||
Instead of replacing all use of TCP by UDP, it's more reasonable to keep using TCP for login and the "all-confirmed downsync inputFrames" from server to players (and possibly "upsync inputFrames" from player to server, but tradeoff on that remains to be discussed), while using UDP for broadcasting inputFrames of each individual player asap (either using p2p or not) just for **better prediction performance**!
|
Instead of replacing all use of TCP by UDP, it's more reasonable to keep using TCP for login and the "all-confirmed downsync inputFrames" from server to players (and possibly "upsync inputFrames" from player to server, but tradeoff on that remains to be discussed), while using a `UDP secondary session` for broadcasting inputFrames of each individual player asap (either using p2p or not) just for **better prediction performance**!
|
||||||
|
|
||||||
|
## How do you actually implement the `UDP secondary session`?
|
||||||
|
It's not a global consensus, but in practice many UDP communications are platform specific due to their paired asynchronous I/O choices, e.g. epoll in Linux and kqueue in BSD-ish. Of course there're many 3rd party higher level encapsulated tools for cross-platform use but that introduces extra debugging when things go wrong.
|
||||||
|
|
||||||
|
Therefore, the following plan doesn't assume use of any specific 3rd party encapsulation of UDP communication.
|
||||||
|
![UDP_secondary_session](./charts/UDPEssentials.jpg)
|
File diff suppressed because one or more lines are too long
BIN
charts/UDPEssentials.jpg
Normal file
BIN
charts/UDPEssentials.jpg
Normal file
Binary file not shown.
After Width: | Height: | Size: 417 KiB |
@ -956,7 +956,7 @@ batchInputFrameIdRange=[${batch[0].inputFrameId}, ${batch[batch.length - 1].inpu
|
|||||||
|
|
||||||
const delayedInputFrameId = gopkgs.ConvertToDelayedInputFrameId(self.renderFrameId);
|
const delayedInputFrameId = gopkgs.ConvertToDelayedInputFrameId(self.renderFrameId);
|
||||||
if (null == self.recentInputCache.GetByFrameId(delayedInputFrameId)) {
|
if (null == self.recentInputCache.GetByFrameId(delayedInputFrameId)) {
|
||||||
// Possible edge case after resync
|
// Possible edge case after resync, kindly note that it's OK to prefab a "future inputFrame" here, because "sendInputFrameUpsyncBatch" would be capped by "noDelayInputFrameId from self.renderFrameId".
|
||||||
self.getOrPrefabInputFrameUpsync(delayedInputFrameId);
|
self.getOrPrefabInputFrameUpsync(delayedInputFrameId);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
Loading…
x
Reference in New Issue
Block a user