I am currently trying to figure out how to tune down the logging intensity of my power meter.
I found an older post related to this subject (but refering to a different model/equipment):
In this post, there is a workaround suggested to prevent the logging mechanism of openHAB from logging specific events. For this, a custom filter was recommended to be added to the logging config in /var/lib/openhab2/etc/org.ops4j.pax.logging.cfg
In OH4, this file still exists as a one-line-referrer to an xml file in the same folder. My issue is that I donât know how to register a custom filter in this xml structure.
This was the recommendation from the post as linked above:
There was a more root-cause-based recommendation, to configure the respective device at its core to tune down the update rate. For the Shelly EM3 which I am using, I searched the settings extensively and also other websites for solutions on that matter. I found the API documentation and something that pointed toward an update interval which I even could change, but it had no effect, my events.log gets flooded with fraction changes on Watt numbers every second for three power lines.
Another tip was to remove the according channels from the openhab thing config. That wouldnât be the preferred approach for me as I still want to monitor the power data, just not on that granularity and with such a high update interval. I use the persistence config to just store the values once every couple of minutes.
Can anyone help me in solving the events.log symptom? How I can register a custom filter in the logging config that supresses the following log entries?
2023-08-31 10:37:15.327 [INFO ] [openhab.event.ItemStateChangedEvent ] - Item 'shellyem38caab561eed3__1721666236_Power_Consumption_1' changed from -124.16 W to -133.93 W
2023-08-31 10:37:15.335 [INFO ] [openhab.event.ItemStateChangedEvent ] - Item 'shellyem38caab561eed3__1721666236_Power_Consumption_2' changed from 94.58 W to 82.15 W
2023-08-31 10:37:15.340 [INFO ] [openhab.event.ItemStateChangedEvent ] - Item 'shellyem38caab561eed3__1721666236_Power_Consumption_3' changed from 114.66 W to 97.93 W
2023-08-31 10:37:17.549 [INFO ] [openhab.event.ItemStateChangedEvent ] - Item 'shellyem38caab561eed3__1721666236_Power_Consumption_1' changed from -133.93 W to -133.8 W
2023-08-31 10:37:17.555 [INFO ] [openhab.event.ItemStateChangedEvent ] - Item 'shellyem38caab561eed3__1721666236_Power_Consumption_2' changed from 82.15 W to 81.13 W
2023-08-31 10:37:17.560 [INFO ] [openhab.event.ItemStateChangedEvent ] - Item 'shellyem38caab561eed3__1721666236_Power_Consumption_3' changed from 97.93 W to 109.52 W
Platform information:
Hardware: IntelÂź CeleronÂź CPU J1900 @ 1.99GHz
OS: Unraid virtual environment - Debian VM running Debian 12
If the channel doesnât let you configure this you might be able to do something in a profile. I think the smarthome/j add-on marketplace has a profile for this but with native OH profiles youâd need to use a transform profile. Create a JS transform under Settings â Transformations along the lines of this:
The value will have to change at least 0.5 from the last returned value before it will return a new value. The Item will still get updated but it wonât change.
The same approach can be used with a timestamp to base it on time instead of the magnitude of the change.
Thanks for this idea, I thought to try it this way first before potentially considering the regex filter approach.
After reading a tutorial on how-to-use-transformations and then some further research (due to slight changes between OH3 and OH4 as I understand, I could finally make it work. Thanks again so much for the code, it would have taken me quite some time to figure it out on my own.
As you instructed, I registered the code as a transformation in Settings â Transformations. Tranformation Type âJSâ.
Saved that and then went to the according thing. Under Channels, I selected the channel and clicked on the linked item.
There I selected âSCRIPT ECMAScript (ECMAScript 262 Edition 11)â which seems to represent the former JS profile name (which was much easier to comprehend ).
Then select the script in the âthing to item transformationâ and good-to-go
P.S: I had to alter the code slightly. The if clause needs to trigger true for the last value being null. I therefore changed to check the cache.private.get(âlastâ) directly. parseFloat apparently returns a NaN if the input value is null, therefore the if check didnât trigger.
Now, the transformation function is working as a charm if being used for exactly one item.
When I use the same function for various items, it stops working because the last value seems to be the value of whatever item the function parsed before the current iteration.
Therefore, on my end, the if clause always triggers because the difference between value of item#2 and value of item#1 is always > THRESHOLD.
Any idea what I have to change to correct that behavior? Dirty workaround would be to duplicate the transformation function for each item but then I would have a full redundancy and not a nice and clean approach.
I wonder if I somehow can catch the item name in the function? Then I could use an array in the transformation function to register every item for which the function gets called and store their last values there.
If thatâs not possible to solve natively, I probably should consider switching to a regex filter after allâŠ
If you just had one JS add-on installed it works just say âJSâ. But you have both so there has to be a way to distinguish between the two.
That is unexpected. It is using the private cache. It must reuse the transform instance across rules instead of creating a separate insurance per rule.
This can be overcome.
I donât think event is defined in a transform but it might be. In that case replace the string 'last' with event.itemName. You donât need an array or anything else. The cache will keep them separated.
If there is no event, you can pass arguments to the transform by appending it to the config config:js:damploggingextend?lastkey=<something unique> where <something unique> is the name of the item or something else unique to this profile. Then replace 'last' with lastKey (no quotes).
As you suspected:
2023-09-01 19:32:45.212 [ERROR] [.module.script.profile.ScriptProfile] - Failed to process script âconfig:js:damploggingextendâ: org.graalvm.polyglot.PolyglotException: ReferenceError: âeventâ is not defined
And as I learned from a different post from you, I used console.log statements for debug reasons, below the result can be seen. no catch is the else path in the code (changes ignored and not logged in events.log), the other one is the if(true) case. I will tune the threshold a bit more and probably make it an argument as well, so that I can use different thresholds for different use cases.
use & between the arguments if there is more than one, just like you see with web pages. More details and examples are in the JS Scripting add-on docs.