Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Superfluous streamUpdateId should be removed and heartbeat tested #17

Closed
3 tasks
Firionus opened this issue Jan 12, 2021 · 3 comments
Closed
3 tasks

Superfluous streamUpdateId should be removed and heartbeat tested #17

Firionus opened this issue Jan 12, 2021 · 3 comments
Labels

Comments

@Firionus
Copy link
Contributor

Firionus commented Jan 12, 2021

Currently, all stream updates use a field called streamUpdateId to ensure the client can detect out-of-order or dropped streamUpdate's.

However, WebSocket operates over TCP which already ensures all messages are in order. If messages cannot be delivered in order after a certain timeout, the connection will be closed.

Therefore, we do not need to ensure order of our messages. However, we have to disconnect the WebSocket if there is a connection issue.

Server-side

Detecting faulty connection should be implemented server-side via ping/pong.

  • Check this is implemented
  • Adjust ping interval to an appropriate value like 1s
  • Adjust pong timeout before connection is closed to an appropriate value like 2s

Client-side

By default, the client will only disconnect after the TCP timeout. I think this is usually pretty long (minutes?) which is too long for us. We should probably adjust the TCP timeout to an appropriate value for us (like 2s).

Final Testing

We should use Cypress to ensure proper behavior when client and server are disconnected. The server should close the WebSocket properly. The client should close the WebSocket and display the appropriate message to the user and try reconnecting.
Both should happen in an appropriate timeframe like 1 or 2 seconds.

Edit: Still needs some research and there's probably bullshit stated above. See e.g.:

@Firionus Firionus added the api label Jan 12, 2021
@Firionus
Copy link
Contributor Author

After reading a bit more, it's probably easiest to implement a ping message in our JSON API and have client and server send it every second or so. Then, if one of them did not receive a ping for 2 seconds, the WebSocket is closed (Basically a double heartbeat). It's simple and should work.

One may say that this is killing connections prematurely that may actually synchronize again at a later time (if the connection is re-established, TCP will request missing packets and eventually synchronize) but this might result in some strange time traveling behavior. Imagine this: You hit GO on your tablet, but nothing happens. You push it again, nothing happens. Now, WiFi comes back and both execute and you've gone one step too far. Possibly critical in a live situation. That's why we should only operate if we can ensure a working connection. Rather block user input so that the user must fix the connection problem at hand than create a non-responsive state whose behavior is unpredictable.

@Firionus
Copy link
Contributor Author

Changes applied in JSON Spec.

TODO

  • New Ping message
  • remove streamUpdateId

@Firionus
Copy link
Contributor Author

Moved to #30 and #31

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

1 participant