-
Notifications
You must be signed in to change notification settings - Fork 311
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
Available payload formatter size is too small #4278
Comments
We have different payload decoders that the console don't support because the size is over 4kb, in this cases we have Comtac, nke-watteco, IMST, digital-matter (5kb file size), Elsys. Also the console throws some errors in switch-case with variables. IMST has two 50kb size file, and nke-watteco all their files are between 20-30 kb. Other cases are less than 16kb. |
we should consider size for devices that are not yet on device repository, for the moment all these including elsys are now on DR so payload formatter is already there. |
Here's a histogram of the number of scripts per kilobyte: Reasons why scripts are too large:
Now, these are actually all valid reasons, and there is little we can do about this. Sure, we can include a non-standard library of useful functions, or obfuscate the code that drastically reduces the file size, but that doesn't make the experience any better. Currently, there's a LoRa Alliance task force under TC about Codec API where a limit is being defined. I think we'll end up somewhere in the range of 32 to 40 KB. Therefore, I think we should consider increasing the limit, also for scripts that are stored per-device AS. Rather, we should think about optimizing storage of AS:
|
Regardless of providing some more space and deduplication, some effort should be expected by the vendors to tame their formatters - huge monolithic blocks of JS does nothing to help the end user with optimisation & alterations. As an interim measure, perhaps increasing the limit on the console so that perhaps a code library could be included. In the meanwhile, I'm in the process of filing a rounding error! |
The original reason for which we actually limited the formatted size was not about storage problems on our side, but rather SLA: In my opinion, we should do the following:
|
Let's do this for 3.13.3. I'd prefer caching the ASTs (by hash) as part of https://github.com/TheThingsIndustries/lorawan-stack/issues/2264. |
My understanding was that it filled up Redis as well as impacting on server resources
Why shouldn't they - otherwise they'll just eat all the resources you put in to it - cars have resource limits. so this isn't an alien concept.
If you keep the original formatter compressed in slower storage for when they are going to be edited, why not minify all of them for the Redis store?
I've looked at how we can attach a device registration to a repository device so it can pickup the payload formatter for some forum users - so there are people around currently copying & pasting formatters that could be picked up from the repository - or as you say, de-duplicated if they are identical |
The limit should exist, it's just that it shouldn't be trivial to hit it, especially with already existing scripts. That's what I wanted to say in my message (but worded it poorly).
My caching proposal refers to this, but instead of keeping the minified script in Redis, we keep the parsed script in the memory of the Application Server. Deduplication then handles the actual storage space minimization in the Redis storage. |
Summary
Available Payload formatter size is too small for some commonly used devices.
Why do we need this?
The default payload formatter's size of Elsys devices is too big for The Things Stack. Same for KLAX, Milesight and NKE devices.
The size of Elsys' payload decoder is ±1000 bytes, The Things Stack allows up to 4 kbytes.
Reference: https://www.elsys.se/en/elsys-payload/
This was no issue in V2.
What is already there? What do you see now?
When Elsys' payload formatter is added, the below error is shown:
What is missing? What do you want to see?
Increase available size to 8 or 16 kB?@neoaggelos see #4278 (comment)
Environment
v3.13.1
How do you propose to implement this?
Get input from Jaime on the minimum required payload formatters size.
How do you propose to test this?
Upload payload formatters of >4 kbytes on test local setup.
Can you do this yourself and submit a Pull Request?
Need input form Jaime and from product team.
The text was updated successfully, but these errors were encountered: