-
-
Notifications
You must be signed in to change notification settings - Fork 242
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
Validator is not thread safe #24
Comments
Agreed, the validator is not thread safe. I'll work on extracting the class variables into something more thread safe to hopefully alleviate these problems in the future. |
This issue in particular is going to take a bit of time to resolve, as much of the validator revolves around utilizing class variables currently. I'll be getting to it, but given the change will affect a lot of aspects I'm going to take a little time to be careful about not breaking anything else. |
That sounds perfectly reasonable to me and thanks for your efforts. Until then, we put a synchronize block around calls to the validator. So there is an, albeit performance limiting, work around. Hmmm... actually, if you think it going to take a while; would you accept a patch to move the lock into the Validator class itself? This way it won't be bite anyone else by surprise, and the lock can be removed when you are able to convert class to instance variables. |
I'll look into adding it into the Validator class; this shouldn't hurt anything anyone else is doing. |
We've been bitten by this, too :(. There's a lot of mutable global state in the validator (in the class variables) that's causing the problem. I think it would be best to refactor things so no access to global mutable state is needed...but in the meantime, here's a simpler suggestion:
No mutex would be needed then. It would change the global state to be global to the thread rather than global to the process. |
The 1.1.0 patch removes most of the global state that is mutable during validation, and a mutex lock has been added around the rest. I need to take some time to refactor the majority of the validation core, as it truly is a mess. Hopefully I'll get around to that in the next couple of weeks... |
👏 |
In a threaded environment we need to synchronize around all calls to Validator.validate!(). Otherwise we get bogus errors like the one shown below. In this case, the referenced file does indeed contain complexText; as it does when successfully run single threaded.
Why are we using threads?: Threaded application server (rack, sinatra on jruby), and trying to validate json against a schema just after it is produced but before it is returned.
I suspect this is due to use of @@class_vars for state in Validator, but I still don't quite understanding it well enough to know if would be reasonable to remove those for instance variables, that would avoid the issue. How might I best help on this? Can I offer a test case that demonstrates the problem to start with?
The text was updated successfully, but these errors were encountered: