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

Fix/rearchitect parallel parser so 1ms wait race condition fix is not necessary #144

Open
thenonameguy opened this issue Feb 5, 2020 · 8 comments

Comments

@thenonameguy
Copy link

In my usecase, I'm only calling a single async resolver that returns in 2ms, this 1ms sleep adds a 50% processing overhead that can be possibly avoided. In case of many-many resolvers this also adds up while also adding a lot of core.async go-block greenthread context switches.

The line in question:

(<! (async/timeout 1))

@wilkerlucio
Copy link
Owner

In high concurrency cases, this prevents deadlock situations, so I think it's a good to keep as default, but I'm ok adding a configuration option to toggle this off, do you want to work on making this? We could call ::pp/disable-pending-check-safeguard? true.

@wilkerlucio
Copy link
Owner

About rearchitect, this problem is likely to go away with new implementations, those were mechanism needed because the old way the parser worked, but the new one can consider all sibling things, so "waiting" thing may go away with that, still working this part out, but it's good to bring it to keep in mind.

@thenonameguy
Copy link
Author

I'm okay if reader3/ a new parallel parser or similar solves these problems in the future. Just wanted to put this on the radar of you/others. I would rather not add an option to that parser can make it lock up depending on the query. This should be solved generally. The other concurrency related timeout safeguards have the same code-smell to it as this one. I hope those get addressed too.

@wilkerlucio
Copy link
Owner

In the meantime, is the async or serial parser not a good option in case you have just small queries? not sure if this is just one specific case of your scenario, but its a good option to consider.

@thenonameguy
Copy link
Author

Our application is async end to end: async webserver, async ring handler, async remotes. Writing an async/thread that blocks on the parser and put's the result in a channel is easy, but is against the point of all the work that we did to make our application scale/use resources better.

@wilkerlucio
Copy link
Owner

I mean using async-parser instead of parallel-parser, for simple queries the async-parser has much less overhead, so unless you are dealing with big queries that can be parallelized, the async-parser may be faster than the parallel-parser, I wonder if that would be good for your scenario.

@thenonameguy
Copy link
Author

thenonameguy commented Feb 7, 2020

Thanks! async-parser with reader3 has done the trick for now. Shaved off 1ms from the p99 as expected, also has way nicer GC properties as it creates less intermediate objects/watchers/etc.

@wilkerlucio
Copy link
Owner

wilkerlucio commented Feb 7, 2020

reader3 still very alpha, if you are doing production releases I suggest you stick with async-reader2 for now.

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

No branches or pull requests

2 participants