-
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
Race condition: running_check, performance concern #21
Comments
Also as a note, you're writing three different files every second in the same function with EDIT: Correction, it saves the files every minute, still. |
Remark: GIL prevents serious concurrency violations from occurring, but I see what your point is - threading is not necessary to solve this problem. |
Relying on the GIL is ugly to say the least. The GIL is not something that's specified somewhere, it's an implementation detail of CPython - what if they're using another implementation? What if someone decides to port the server to Cython eventually? |
You can still have a concurrency violation even with the GIL. Two coroutines concurrently modifying a complex shared resource may result in unintended behavior. |
Looks a bit better now, but there's still some things: tsuserver3/server/tsuserver.py Lines 144 to 145 in 32657d5
This function doesn't need to be async - all it does is create (and return) a new task in the event loop, which isn't an asynchronous action. And if that one is not asynchronous, this line is redundant: tsuserver3/server/tsuserver.py Line 98 in 32657d5
That's all for the asynchronous part, as far as I can see. |
Here:
tsuserver3/server/tsuserver.py
Lines 134 to 146 in b1bddd6
A thread changes
area.last_talked
, which is later changed here, but in a separate thread.tsuserver3/server/aoprotocol.py
Lines 401 to 404 in b1bddd6
The timer, if anything, should work asynchronously sharing the same asyncio event loop as the protocol code. This way there is a race condition where you are reading/writing a value in two separate threads.
Furthermore, you're creating a new
Timer
every second instead of reusing one, which is going to be slow, as there is a new thread spawned and killed every second.Also, the
runner
variable doesn't seem to do anything. What is the point of it?I also suggest removing the timer entirely and creating a solution that compares timestamps instead of a timer that runs every second.
The text was updated successfully, but these errors were encountered: