-
-
Notifications
You must be signed in to change notification settings - Fork 39
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
[FR] Websockets for logging, streaming cadence, power, etc #173
Comments
@bau-sec This would be great. We would love to use websockets and the AsyncWebServer. There have been issues in the past getting the AsyncWebServer and NimBLE-Arduino working well together. I think this could fit in well with the new logging changes I have in the "Improved Logging" PR. Here is an example of someone doing websockets for debug logging: https://github.com/ayushsharma82/WebSerial |
I threw some stuff together to start experimenting w/ ESPAsyncWebServer in PR #178. So far it runs on the ESP, but I haven't tried to ride w/ it yet or connect to bluetooth devices. Do you remember what the issues were combining ESPAsyncWebServer with NimBLE? |
You will get some nice crashes. Search on NimBLE-Arduino and ESPAsyncWebServer and you will find some mention for sure. Sorry, I don’t have the links handy. |
It's an awesome Idea. I've just hit big roadblocks in the past with Async. :( We could do it all with Bluetooth. Just have to write a bunch of multi platform client apps :) Unfortunately this doesn't work on mobile devices (apple) yet: https://balenalabs-incubator.github.io/balena-web-ble/ I guess there is this: That really might not be a horriBLE solution if someone wanted to check it out. |
It's wishful thinking, but worth a go. If I had a quick way to test it I would try it out but that might not work for this repo. I sadly gave up on async long ago for much the same reasons @doudar did, it's just too hard to get stable and the dev is too busy to address the issues. Recent updates of IDF and Arduino might provide some relief though if anyone is interested in testing. |
I commented on the PR too, but I'll take a look this weekend, should be pretty quick to see the state of things w/ the arduino and NimBLE updates. |
@bau-sec , have you had been able to check into this at all? |
For logging UDP could be an alternative way to submit messages. I've used UDP in another Arduino project for logging together with https://github.com/couchcoding/Logbert. |
We’ve freed up a bunch more memory with the latest arduino updates. Give it a go if you’d like. Sounds promising! |
As of 12/31/2021, it appears there is still an issue in arduino core preventing stability when using both BLE and asyncTcp simultaneously. |
@MarkusSchneider , I think we are starting to have occasional issues with ISR's not getting recognized (shifter presses) over time as the WiFI radio gets bogged down with too much traffic from logging. Thinking about this, I'm seeing two options:
Thoughts? |
I confirm, a unique interface for all use case (logging, status apps, html logging) would be the best. |
I love the UDP logging btw, it's leaps better the the HTML logging for recording a whole session, but if you just want to glance at the log quickly, the HTML log is very easy. |
!!!!!! It looks like maybe this library implements websockets without having to use asynctcp library! (but also allows the use of async in the future if it becomes stable with BLE). |
In our potential release testing tonight, one of the users reported having the same issues as you while UDP logging was enabled. BLE kept timing out and disconnecting. I think it's because the logging stream is so steady that it's not allowing breaks between for BLE communication. I think we may be able to use bursts of UDP logging with a buffer like you mentioned previously. I believe @kadaan already had a solution for that, which we currently use in the http debugging interface. It's here: Line 17 in a6220ed
and here: Lines 33 to 41 in a6220ed
We would just need to use that and direct the logs to the UDP logger on a specified interval. I think the best place would be here: Lines 156 to 161 in a6220ed
Just modify the timer value to every 2 seconds or something. Currently that timer isn't being used, but I plan to expand that to check for wifi connectivity. |
Your solution will also ensure that BLE task is no longer blocked by udp-logging because main task will do that in background 👍. |
I would prefer to use a queue SmartSpin2k/src/BLE_Client.cpp Line 518 in a6220ed
instead of using a shared memory buffer. The semaphore in the buffer will block adding log messages if the messages are processed and the caller must wait or the message is rejected. A queue decouples writing and reading completely. |
I'm open to either, I wanted to make sure that you knew the other option was available as well. At some point we would want messages to be dropped, but we currently serve 15k webpages without issue so we are probably restricted more by esp32's memory. If you turn on the stack debug, you'll want to look at the "best block" for an idea on how much we have to work with. |
@MarkusSchneider , new branch https://github.com/doudar/SmartSpin2k/tree/websockets-no-async has an infant implementation of websockets working for the html debug. So far, it works really slick. I haven't ride tested it yet and there's a lot that would need to be converted over (like for userConfig and rtConfig). Also not sure how to get these out into something like Logbert yet. |
Hi Anthony, We can then define and enable different logging strategies by creating an instance of a logger. In SSKLog Lines 72 to 82 in a6220ed
Push the log message to a Queue or MessageBuffer (I don't know what kind of buffer is better for sending strings). In the main.cpp register/create the appender and in the main-loop, read all messages from queue or message-buffer and loop over the log-appenders to write messages to sink. Advantages
Disadvantages
What do you think? |
I’m all for it, and agree that it should reduce the issues we’re having with logging. Startup messages will probably always have to be gathered via serial, or made less verbose. Speaking of verbosity, I wonder if there’s a way to reduce characters transmitted while retaining information and readability. Such as, sending all common constants in the logging data (such as the log tags) to the client at startup and then encoding them to a single uint8_t, then decoding them for display on the client. Probably too complex and may introduce more issues though. Along this same line, we could reduce verbosity by utilizing log levels more and making the log level run time selectable via the interface. If websockets prove stable, they would be perfect for this as we could specify log level by the web socket constructor on the client. |
we can gzip the messages. But then we have to build owner own log monitor with the unzip functionality. |
^^ I’m reading that the websocket protocol supports text compression on the fly. Maybe that small library we have supports it (I doubt it). Also, I edited the comment above with more information ^^ |
Nice @MarkusSchneider ! I see your updates to that branch. I'm going to ride test it ASAP and see if we're stable. Looks awesome! |
This should be merged with Wahoo Dircon as it’s an established protocol for sending FTMS data via udp. The issue I have is that the mdns library needs to be modified and it’s part of the IDF so it needs to be compiled into our own version of arduino-core |
Is your feature request related to a problem? Please describe.
For the debug info page, the javascript refreshes debug info every second or so. I'm envisioning a dashboard that is similar to the debug info page, but it displays current cadence, power, connected devices, think a bike computer basically. This would be useful riding outside of zwift or similar apps. To make something like that work well, websockets would be nice. Rather than refreshing every second which can create lag between when the measurement was taken and when we actually read it on the refresh, it would be nice to have websockets allowing the SS2K to push out the measurement as soon as it happens.
This would also be nice for logging since the log message can be pushed out immediately rather than cached to a buffer waiting for a client to pull it down.
Describe the solution you'd like
If we switch to ESPAsyncWebServer (https://github.com/me-no-dev/ESPAsyncWebServer) we'd get websockets and server side events to handle this scenario.
Describe alternatives you've considered
Just leaving it the way it is w/ the client webpage making requests every second or so to refresh data
Additional context
I was thinking about starting a branch to swap our Webserver.h calls to use ESPAsyncWebServer, but wanted to gauge interested before going down that path. I'd probably wait until the native testing PR was in since that's a big reorg.
The text was updated successfully, but these errors were encountered: