Homematic Binding: not all devices read from CCU

I yesterday faced this issue for a Homematic (not IP) device. Not sure, if more items where affected. It’s a rain sensor, so I will wait until the next rain starts and see, if it’s resolved after I needed to restart my system for another purpose.
The device was just not updated in OH, but I could see the correct actual status in the frontend of raspberrymatic on my ccu3.
Unfortunately it’s quite hard to get aware of devices, that don’t get updated anymore, because they don’t get updated anymore :slight_smile:

These type of problems are really hard to trace and solve. It seems to depend on the CCU version (CCU2 seems to cause more problems than the faster CCU3), the network configuration and stability (on Raspis you should always use an ethernet cable and not WiFi) and also on the device types that are used (it seems that HmIP devices are causing more trouble than the older devices).

For example, I am running Raspberrymatic and openHAB on two different Raspi 3 (no docker or VM) without any problems for weeks.

Let me explain how the communication between OH and the CCU works: when the binding is started, it asks the CCU for information about all devices and requests the current values of all data points. Then it registers itself as a receiver for events (exactly speaking it has to register a maximum of three receivers: for HM-RF, HmIP and Groups). Every time a device value changes, the CCU sends an event to the registered OH installation(s).

If the network is stable, this can work perfectly for weeks. If the connection is broken, the binding tries to reconnect and register itself as an event receiver. But if the previous event registration was not removed correctly from the CCU, this can cause problems on the CCU side (and the binding no longer receives values). This is at least what I detected. During my connect handling tests, I even ended up with a CCU that I had to restart via ssh because the web interface was no longer working correctly.

If you detect such communication issues again, you can try to ssh into the CCU, go to directory /var/log. There are two log files that can help in this situation: hmserver.log and messages.

1 Like

Hello,
I am new to openhab and homematic and did a test setup at home before starting to implement complete integration. And I have exactly the same issue as TS reports. In my test setup I have just about 10 devices and one system variable. Only 2 of them plus variable are configured in openhab. When I setup binding all works just fine. Also it continue working for days until I reboot openhab. I guess it would never work if some ports are closed, but from other side what I have observed, that during openhab tries to activate binding and devices, the CCU3 works very bad. By bad I mean I can log-in until this point all is fine, but when I try to check device status or any other page it is just stuck (CCU3 UI). It shows some progress like rotating wheel or popup and never goes back.
I did not deep inside the issue yet, but I have feeling, that openhab does some API calls on CCU3, that makes CCU3 stuck. At the same time top command on CCU3 shows, that CPU is almost 0% usage and a lot of free RAM. This could be a sign, that CCU3 is also waiting for something. May be does a some scan or so. But also could be some stuck in communication with openhab. Will try to debug if I decide to stay with openhab (which is most probable…).

With best regards,
Mike.

Small update. I can reproduce it 100%. As soon as I start openhab after about 30 seconds, CPU usage drops to 0% on CCU3 and on UI I can not see duty-cycle green bar any more. So means some RF related part is stuck. And from this point I can not open any page. I have second CCU3 with fresh installed Raspberrymaticn (current one is a native CCU3 with the latest firmware) and will try to reconfigure it with openhab and test different scenarios like add gateway without any device configured in CCU3. Add device to CCU3 but not to openhab, Add device to openhab. And test at which point it stuck. Theretically also possible, that my current CCU3 has some garbage, but as not only me who has an issue I would guess it should be some genric reason.
With best regards,
Mike.

UPDATE:
Indeed CCU3 is stuck. I want to remove all extensions before resetting it first.

  683     1 root     S    23588   2%   0% /bin/rfd -f /etc/config/rfd.conf -l 5
Oct 25 15:35:48 ccu3-webui daemon.info node-red[1578]: [ccu-connection:localhost] Interfaces: ReGaHSS, BidCos-RF, HmIP-RF, VirtualDevices
Oct 25 15:35:48 ccu3-webui daemon.info node-red[1578]: [ccu-connection:localhost] Interface ReGaHSS connected
        at org.apache.http.impl.client.DefaultRequestDirector.tryExecute(DefaultRequestDirector.java:686) ~[HMIPServer.jar:?]
        at org.apache.http.impl.client.DefaultRequestDirector.execute(DefaultRequestDirector.java:488) ~[HMIPServer.jar:?]
        at org.apache.http.impl.client.AbstractHttpClient.doExecute(AbstractHttpClient.java:884) ~[HMIPServer.jar:?]
        at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:82) ~[HMIPServer.jar:?]
        at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:107) ~[HMIPServer.jar:?]
        at org.apache.http.impl.client.CloseableHttpClient.execute(CloseableHttpClient.java:55) ~[HMIPServer.jar:?]
        at de.eq3.cbcs.legacy.communication.rpc.internal.transport.http.HttpTransport.sendRequest(HttpTransport.java:106) ~[HMIPServer.jar:?]
        at de.eq3.cbcs.legacy.communication.rpc.internal.rpc.RpcClient.sendRequest(RpcClient.java:94) ~[HMIPServer.jar:?]
        at de.eq3.cbcs.legacy.communication.rpc.internal.rpc.RpcClient.invoke(RpcClient.java:82) ~[HMIPServer.jar:?]
        at com.sun.proxy.$Proxy41.newDevices(Unknown Source) ~[?:?]
        at de.eq3.cbcs.legacy.bidcos.rpc.internal.LegacyBackendClient.newDevices(LegacyBackendClient.java:157) ~[HMIPServer.jar:?]
        at de.eq3.cbcs.legacy.bidcos.rpc.internal.DeviceUtil.synchronizedBackendDevices(DeviceUtil.java:232) ~[HMIPServer.jar:?]
        at de.eq3.cbcs.legacy.bidcos.rpc.internal.InterfaceInitializer.handle(InterfaceInitializer.java:109) ~[HMIPServer.jar:?]
        at de.eq3.cbcs.legacy.bidcos.rpc.internal.InterfaceInitializer.handle(InterfaceInitializer.java:26) ~[HMIPServer.jar:?]
        at io.vertx.core.impl.AbstractContext.dispatch(AbstractContext.java:100) ~[HMIPServer.jar:?]
        at io.vertx.core.impl.WorkerContext.lambda$emit$0(WorkerContext.java:59) ~[HMIPServer.jar:?]
        at io.vertx.core.impl.WorkerContext$$Lambda$91/24996555.handle(Unknown Source) ~[?:?]
        at io.vertx.core.impl.WorkerContext.lambda$execute$2(WorkerContext.java:104) ~[HMIPServer.jar:?]
        at io.vertx.core.impl.WorkerContext$$Lambda$92/13535296.run(Unknown Source) ~[?:?]
        at io.vertx.core.impl.TaskQueue.run(TaskQueue.java:76) ~[HMIPServer.jar:?]
        at io.vertx.core.impl.TaskQueue$$Lambda$29/7182616.run(Unknown Source) ~[?:?]
        at java.util.concurrent.ThreadPoolExecutor.runWorker(ThreadPoolExecutor.java:1149) ~[?:1.8.0_202]
        at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:624) ~[?:1.8.0_202]
        at io.netty.util.concurrent.FastThreadLocalRunnable.run(FastThreadLocalRunnable.java:30) ~[HMIPServer.jar:?]
        at java.lang.Thread.run(Thread.java:748) ~[?:1.8.0_202]
2022-10-25 15:37:29,223 io.vertx.core.impl.BlockedThreadChecker WARN  [vertx-blocked-thread-checker] Thread Thread[vert.x-worker-thread-0,5,main] has been blocked for 198574 ms, time limit is 60000 m
s
io.vertx.core.VertxException: Thread blocked
        at java.net.SocketInputStream.socketRead0(Native Method) ~[?:1.8.0_202]

The Homematic binding does nothing special to block the CCU. This can only happen if you have multiple connections to the CCU open at the same time. Or if you start/stop the binding very often and the binding was not able to unregister from the CCU.

I am using Raspberrymatic with > 10 devices (all 3 types) on an Raspi 3 together with OH 3.3 without any problems. Only when I am debugging the binding the CCU can be blocked after some time with lots of restarts.

Do you have node-red running on your CCU? Your log message shows “node-red”. Maybe this causes the problem together with OH.
Also, please tell us a bit more about your configuration (Hardware, network types, OH version).

Hello Martin,

Thank you for your help!

tl;dr; Problem solved, and I am kind of noob :slight_smile:

Any way could be some of reported here issues are the same by nature, so I will describe my steps to find the issue and how I have solved it.

First, my configuration:
CCU3 original from Homematic
Intel Notebook with 2 cores and 4GB RAM running Linux Ubuntu 22.04.1 LTS on NVMe
OH latest 3.3.0

What I have tried:
CCU3 flashed with Raspberrymatic (latest) and several devices connected to the CCU3.
CCU3 with Raspberrymatic after reset to defaults and no devices.
CCU3 with ccu3-3.65.8
CCU3 with ccu3-3.65.11
Additionally, I have re-installed OH with completely wiping the configuration.

In all above cases, I had the following issue:
I can add CCU3 and any other thing. It works fine and instant.

As soon as I restart OH, CCU3 is stuck. It does not matter which version of CCU3 software I use. OH is not able to connect to the CCU3 and reports error.

Next I decided to dive inside, so I have checked out OH project, configured remote debug and start Java debugger to see what is going on. All this I did on my Windows PC and, as it must be, I could not reproduce the issue. As soon as OH is up, it almost instantly connects to CCU3 with all defined things. First idea was, that my PC by many orders faster than running notebook with Linux and this could be an issue, but then I have realized that I have forgot the key point - firewall. All the time I thought and checked the firewall on CCU3, but not on my Linux server. If we check documentation for Homematic binding we can find this:

And FROM the gateway to the binding:
XML-RPC: 9125
BIN-RPC: 9126

Dunno why it works to setup homematic at first time, but it is definitely an issue when OH is starting and initializes bridges. Also I would say it is kind of bug in the Homatic CCU3. Even if CCU3 could not respond to the client, it should not kill the system. After opening mentioned above ports on my Linux PC now all works like a charm! Moreover, when I check open ports on my Linux server I see, that 9125 is opened and in use. I feel a shame, but who never makes a mistake…

So thank you all for the collaboration in this topic and I do really hope my finding could help someone.

With best regards,
Mike

1 Like

Hello everyone!
While searching for a solution to a similar problem with my setup, I stumbled across this thread. It appears I have managed to fix it, so I’d like to share the details of my setup and my solution:

TL;DR Entering the Address of my openHAB as Callback Network Address in the Thing config of the CCU seems to have solved the problem.

I have openhab running as a docker container inside a Proxmox LXC container, which is working fine.
For the Homematic Stuff I use RaspberryMatic running in a Proxmox VM, with a HmIP-RFUSB.

Both systems work well independently, but when I enable the Homematic Binding in openHAB and add Things, seemingly random error messages appear in the openHAB Things and the WebUI of the CCU (RaspberryMatic) freezes on “Loading…” when trying to login.

After disabling the Binding in OH and rebooting the CCU VM, I can login into it again normally.
Sometimes the defined Things also show up as “Online” in openHAB but don’t get any Item updates, and controlling the Items also doesn’t work.

OH and the CCU are both on the same subnet, though OH also has an IP configured on another subnet (which I use for MQTT devices). It seems to be the cause of the problem that when the Thing configuration parameter “Callback Network Address” of the CCU is left empty, it probably chooses the wrong address which isn’t on the same subnet as the CCU - hence the communication between the two won’t work properly (or not at all). I do not know why that causes the WebUI of the CCU to freeze entirely.

Hope this maybe helps somebody!

Ok tha was my issue, I am running OH inside a docker container with networkmode “host”.
That causes that the binding does not know what the callbackHost parameter is with all that network devices I guess.
I put in the openhab url with port and now I have the missing 5 homematic devices in my Inbox =)
Ty @mva_one you post helped a lot!

FTR. I had a similar issue where many (all?) homematic devices entered “ERROR: CONFIG” state, while the gateway (CCU2) as ONLINE.

Changing the buffersize from 2048 to 4096 made the devices ONLINE again. However, I suspect that it could be possible that its not the new value of buffersize that “fixes” this, but rather that changing the buffersizes triggers something that fixes the issue.

Besides that, openhab.log containted an exception, not sure if it is relevant.

OpenHAB Homematic exception.

kio=1,kro=1}->HttpConnectionOverHTTP@617de925(l:/192.168.188.43:36730 ↔ r:/192.168.188.41:9292,closed=false)=>HttpChannelOverHTTP@50568aa4(exchange=HttpExchange@fe8e273{req=HttpRequest[POST /groups HTTP/1.1]@152166a[TERMINATED/null] res=HttpResponse[null 0 null]@38386ab3[PENDING/null]})[send=HttpSenderOverHTTP@5c5fc4ba(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@14ec4e38{s=START}],recv=HttpReceiverOverHTTP@51ceb89(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]
java.io.IOException: java.util.concurrent.ExecutionException: java.io.EOFException: HttpConnectionOverHTTP@617de925::SocketChannelEndPoint@7729df4c{l=/192.168.188.43:36730,r=/192.168.188.41:9292,ISHUT,fill=-,flush=-,to=8/0}{io=1/0,kio=1,kro=1}->HttpConnectionOverHTTP@617de925(l:/192.168.188.43:36730 ↔ r:/192.168.188.41:9292,closed=false)=>HttpChannelOverHTTP@50568aa4(exchange=HttpExchange@fe8e273{req=HttpRequest[POST /groups HTTP/1.1]@152166a[TERMINATED/null] res=HttpResponse[null 0 null]@38386ab3[PENDING/null]})[send=HttpSenderOverHTTP@5c5fc4ba(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@14ec4e38{s=START}],recv=HttpReceiverOverHTTP@51ceb89(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]
at org.openhab.binding.homematic.internal.communicator.client.XmlRpcClient.send(XmlRpcClient.java:120) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.client.XmlRpcClient.sendMessage(XmlRpcClient.java:73) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.client.RpcClient.setChannelDatapointValues(RpcClient.java:245) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.AbstractHomematicGateway.setChannelDatapointValues(AbstractHomematicGateway.java:522) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.CcuGateway.setChannelDatapointValues(CcuGateway.java:109) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.AbstractHomematicGateway.loadChannelValues(AbstractHomematicGateway.java:493) ~[?:?]
at org.openhab.binding.homematic.internal.handler.HomematicThingHandler.loadHomematicChannelValues(HomematicThingHandler.java:486) ~[?:?]
at org.openhab.binding.homematic.internal.handler.HomematicThingHandler.updateChannelState(HomematicThingHandler.java:466) ~[?:?]
at org.openhab.binding.homematic.internal.handler.HomematicThingHandler.updateDatapointState(HomematicThingHandler.java:412) ~[?:?]
at org.openhab.binding.homematic.internal.handler.HomematicBridgeHandler.onStateUpdated(HomematicBridgeHandler.java:281) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.AbstractHomematicGateway.lambda$1(AbstractHomematicGateway.java:744) ~[?:?]
at org.openhab.binding.homematic.internal.misc.DelayedExecuter.start(DelayedExecuter.java:65) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.AbstractHomematicGateway.eventReceived(AbstractHomematicGateway.java:741) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.server.RpcResponseHandler.handleEvent(RpcResponseHandler.java:98) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.server.RpcResponseHandler.handleMethodCall(RpcResponseHandler.java:51) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.server.XmlRpcServer$ResponseHandler.handle(XmlRpcServer.java:125) ~[?:?]
at org.eclipse.jetty.server.handler.HandlerWrapper.handle(HandlerWrapper.java:127) ~[bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.server.Server.handle(Server.java:516) ~[bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.server.HttpChannel.lambda$handle$1(HttpChannel.java:487) ~[bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.server.HttpChannel.dispatch(HttpChannel.java:732) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.server.HttpChannel.handle(HttpChannel.java:479) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.server.HttpConnection.onFillable(HttpConnection.java:277) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.io.AbstractConnection$ReadCallback.succeeded(AbstractConnection.java:311) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.io.FillInterest.fillable(FillInterest.java:105) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.io.ChannelEndPoint$1.run(ChannelEndPoint.java:104) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.runTask(EatWhatYouKill.java:338) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.doProduce(EatWhatYouKill.java:315) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.tryProduce(EatWhatYouKill.java:173) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.util.thread.strategy.EatWhatYouKill.run(EatWhatYouKill.java:131) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.util.thread.ReservedThreadExecutor$ReservedThread.run(ReservedThreadExecutor.java:409) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.util.thread.QueuedThreadPool.runJob(QueuedThreadPool.java:883) [bundleFile:9.4.52.v20230823]
at org.eclipse.jetty.util.thread.QueuedThreadPool$Runner.run(QueuedThreadPool.java:1034) [bundleFile:9.4.52.v20230823]
at java.lang.Thread.run(Thread.java:840) [?:?]
Caused by: java.util.concurrent.ExecutionException: java.io.EOFException: HttpConnectionOverHTTP@617de925::SocketChannelEndPoint@7729df4c{l=/192.168.188.43:36730,r=/192.168.188.41:9292,ISHUT,fill=-,flush=-,to=8/0}{io=1/0,kio=1,kro=1}->HttpConnectionOverHTTP@617de925(l:/192.168.188.43:36730 ↔ r:/192.168.188.41:9292,closed=false)=>HttpChannelOverHTTP@50568aa4(exchange=HttpExchange@fe8e273{req=HttpRequest[POST /groups HTTP/1.1]@152166a[TERMINATED/null] res=HttpResponse[null 0 null]@38386ab3[PENDING/null]})[send=HttpSenderOverHTTP@5c5fc4ba(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@14ec4e38{s=START}],recv=HttpReceiverOverHTTP@51ceb89(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]
at org.eclipse.jetty.client.util.FutureResponseListener.getResult(FutureResponseListener.java:118) ~[?:?]
at org.eclipse.jetty.client.util.FutureResponseListener.get(FutureResponseListener.java:110) ~[?:?]
at org.openhab.binding.homematic.internal.communicator.client.XmlRpcClient.send(XmlRpcClient.java:110) ~[?:?]
… 32 more
Caused by: java.io.EOFException: HttpConnectionOverHTTP@617de925::SocketChannelEndPoint@7729df4c{l=/192.168.188.43:36730,r=/192.168.188.41:9292,ISHUT,fill=-,flush=-,to=8/0}{io=1/0,kio=1,kro=1}->HttpConnectionOverHTTP@617de925(l:/192.168.188.43:36730 ↔ r:/192.168.188.41:9292,closed=false)=>HttpChannelOverHTTP@50568aa4(exchange=HttpExchange@fe8e273{req=HttpRequest[POST /groups HTTP/1.1]@152166a[TERMINATED/null] res=HttpResponse[null 0 null]@38386ab3[PENDING/null]})[send=HttpSenderOverHTTP@5c5fc4ba(req=QUEUED,snd=COMPLETED,failure=null)[HttpGenerator@14ec4e38{s=START}],recv=HttpReceiverOverHTTP@51ceb89(rsp=IDLE,failure=null)[HttpParser{s=CLOSED,0 of -1}]]
at org.eclipse.jetty.client.http.HttpReceiverOverHTTP.earlyEOF(HttpReceiverOverHTTP.java:385) ~[?:?]
at org.eclipse.jetty.http.HttpParser.parseNext(HttpParser.java:1621) ~[?:?]
at org.eclipse.jetty.client.http.HttpReceiverOverHTTP.shutdown(HttpReceiverOverHTTP.java:269) ~[?:?]
at org.eclipse.jetty.client.http.HttpReceiverOverHTTP.process(HttpReceiverOverHTTP.java:185) ~[?:?]
at org.eclipse.jetty.client.http.HttpReceiverOverHTTP.receive(HttpReceiverOverHTTP.java:80) ~[?:?]
at org.eclipse.jetty.client.http.HttpChannelOverHTTP.receive(HttpChannelOverHTTP.java:131) ~[?:?]
at org.eclipse.jetty.client.http.HttpConnectionOverHTTP.onFillable(HttpConnectionOverHTTP.java:172) ~[?:?]
… 11 more