-
Notifications
You must be signed in to change notification settings - Fork 7
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
Locking inconsistencies #335
Comments
Here is another flaw I just discovered As you can see in the console logs, my clientId and the connectionId match the ones listed as However, spaces seems unable to match my own client and connection id against the members and therefore marks myself as This happened after going into hibernation and waking up my machine again. |
@bastiankistner thanks for the detailed report, I've raised this internally, we'll review and get back to you. |
Regarding the locking inconsistencies: It seems that when I decrease the |
Hi @bastiankistner ! I will be looking into the locking inconsistency issues. You mentioned you could provide a repo with a reproducible setup - this would be really helpful, so please send it if you have it around. |
Hello @VeskeR , I'm still trying to integrate spaces properly and will provide a repo as soon as I'm through. A little question in the meantime: Is it possible to limit the token capabilities to exactly the space only? |
Hi there,
I am in high demand for a realtime locking solution so I went on giving ably a try. I've been using channels previously, which works ok as long as I don't rely on events but continuously run certain checks (e.g. with requestAnimationFrame or requestIdleCallback). I also moved away from using the react integration because error handling is really badly implemented!
I thought I'd give spaces a chance but already after a few nights playing with it, I'm facing inconsistent situations with a probability of at least 10 to 20%. After I simulate connection issues, locks are not properly being released on all clients and I can even kind of reproducibly trigger situations where more than one client holds a lock for the same id.
The internals of the SDK reflect an inconsistent state. Even though, my clients reconnect and I'm not maintaining state information about locks but instead always call the
getAll
,getOthers
andgetSelf
methods as described in the docs, the SDK instances seem to hold outdated and invalid data. They don't update unless I re-acquire and release the within a client that carries the correct state or disconnect a client so that certain updates seem to be triggered.Am I doing something wrong? Or is version 0.4 (internally) known to be unreliable?
Ably could be such a great product for far more than 500 customers, if only developer experience would be improved.
I attached a screenshot. You would certainly need the sources to understand what's going on. But it's the exact same application, running in two different tabs, using the public api key, a client id generated with crypto.randomUUID() and nothing fancy but a few react components and a singleton class handling ably realtime with members and locks and a store that can be used in combination with react's
useSyncExternalStore
. And it shows that each client holds a lock for iddummy1
. Members shows self and others and the Lockable Item's purpose is to provide two buttons for lock/unlock.I could provide a repo with it if it helps.
The text was updated successfully, but these errors were encountered: