-
-
Notifications
You must be signed in to change notification settings - Fork 13
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
Include on/scope_components into AdvisoryLock Name #23
Comments
Hi @palexvs, I'm currently away on annual leave and can look at this a bit deeper when I return next week. But to answer the question quickly, we just lock down to the column name as the Would be so good to be able to reproduce it in a test too :) Let me know if that situation changes :) |
I would second this, as right now, given a high enough level of concurrency given the current advisory lock setup, will result in requests that won't even interact at all, end up deadlocking each other. |
no worries, thank you for letting me know!
Unfortunately, I could not reproduce it, but I had several times on production
From my understanding, when two different users update/create their tasks simultaneously, |
I can say that from attempting to resolve this (production is fun to debug these sorts of things), but I was looking at some sort of tenant_id that could be more specific to the item being positioned. That would at least lessen the scope here, but yeah there needs to be a more granular lock as this one effectively locks the whole table, regardless of if there are unrelated changes to position or even unrelated to the scope relevant to the item being positioned. |
Yea, the more I look at this, the more flaws I can see in what I've come up with so far. To make it more granular will require embedding the advisory lock much deeper in the mechanisms code and then creating a way to globally release any relevant locks on commit or rollback. Will have a stab at it and see where I get to. |
Now when I scope the lock right down to the position scope I'm getting deadlocks again. Quite strange. Will keep plugging away. |
Looking at this further, perhaps we could do away with an advisory lock altogether and just lock all the scopes that are Please let me know your thoughts on this. In the case where there is no scope then we'd need to lock the entire table. |
Please check out this branch: https://github.com/brendon/positioning/tree/advisory-lock And comment in this PR on anything specifically relating to the change to scope locks. My particular concern is what to do when there is no scope. Currently I'm locking all the rows in the table but apparently this won't prevent new rows being added during this process. I guess it might still work because other processes trying to add new records will need to obtain a lock as they do their positioning adjustments. I wonder if it's enough to just lock the first record in the table? |
thank you @brendon ! Sorry, was busy, will try this weekend |
Thanks @palexvs. Hope it went well :) |
I can say that, under sort of maybe mid level load, I did away with the advisory locks entirely and am relying on a unique index instead. This seems to work well enough for my purposes. Personally, I'm leaning towards letting sleeping dogs lie for my implementation as the locking as it was ended up with production outages for me. |
Thanks @ragingdave. I'll probably look to do away with advisory lock altogether and replace it with what's in that fork. Since it adds row locking of various kinds I'll make it a minor release as it could potentially cause more problems. If you want to have a go running that on your production environment, let me know your results. I'm done with it apart from trying to get the tests to work with sqlite. https://github.com/brendon/positioning/tree/advisory-lock |
Advisory Lock is gone so I'll close this :) |
@brendon thank you! |
Nice :) |
Hi, recently we started using the Positioning gem, and it works perfectly, except sometimes
SELECT pg_advisory_lock(?)
fails due to Postgres statement_timeout (5 minutes). I could not reproduce it, but I guess it is due to the same lock_name between requests even when they work with records from different scopes (positioned on: [...]
)Is there any reason why the lock_name is the same for a table? Is it possible to include scope_components here to allow process clients requests simultaneously instead of consequentially
Thank you
The text was updated successfully, but these errors were encountered: