-
Notifications
You must be signed in to change notification settings - Fork 197
New issue
Have a question about this project? # for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “#”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? # to your account
HTTP server hard to use with any locks in handlers and it should be in the documentation #512
Comments
I'm not sure what else I could add to the topic, besides pointing you to this explanation. Also, I'm not really sure in the details of your implementation, as it is explained with a few words, rather than with code. Perhaps an easy(er) solution would be to just send the data when you are no longer holding the lock?
Yes, that would be ideal. However, if somebody does not do it, it will be never done. In the meantime, I've moved away from the ESP IDF websockets client/server impls, as they are not really async, and have a lot of restrictions. I am personally actively working on and trying to use |
Hey, first of all sorry if my bug report offend you in any way, and thank for all work you done for the community. I don't mind to make a PR with the documentation changes and another one with example when I manage to create one. |
Sorry if I sound offended - not at all! But we have to be transparent with the community as to what level of support they could expect in the We may even put some wording in the READMEs that this effort is not sponsored by Espressif soon. |
I want to bring back #287. I stumbled on it, and I think it has to be mentioned in the documentation and an example of writing HTTP server with state would be ideal.
I have next scenario:
Because of the single thread server main thread holding the lock and trying to send which waits for result and the server thread trying to obtain the lock to get access to data.
I think it should work If I split the mutex in two, one for data and one for web socket sessions, and I also use a channel to handle web socket events.
The text was updated successfully, but these errors were encountered: