Do you have some Updates regarding multiple border routers?
Iām thinking on this some ā¦ I already have two HA instances, each instance running OTBR-AddOn w. Thread/OTBR Integration. I have both TBRs using the same Thread dataset, so they are both on the same Thread network. Each Thread integration knows its local dataset as well as the remoteās dataset.
So in the case where there is only one HA instance running a local OTBR AddOn and there is the desire to have a second OTBR instance on another machine but controlled by the one HA instance, then is it the case that the second OTBR is not implemented as an HA AddOn, but something else (Docker)?
If no, and the second OTBR is an AddOn running on a second instance of HA, then what would be the advantage of having one HA instance control the OTBR of the second instance?
Best Regards
Iām interested in this too. Iāve been looking forward to using thread like WiFi, deploy PoE TBRs like you would an access point. Deploy additional TBRs for redundancy and to increase coverage. In my deployment, WiFi is my strongest and most resilient signaling protocol because I have 3 APs. Its only drawback is battery powered devices. Iām hoping thread can solve for that.
@agners Thanks for your work on OTBR! Does this PR help improve stability in networks that mix Apple Home and OTBR devices?
I recently added a SkyConnect to my Home Assistant server, joining it to an existing Thread network. Since then, most of my Thread devices frequently go offline. The only Thread device I can monitor is my HomeKit device: it stays online for 1-3 minutes, then goes offline, and reliably reconnects exactly 30 minutes later. I cannot track the thread status of all my Matter devices, as the Matter integration doesnāt seem to log the status.
About a year ago, I merged my Apple Home and OTBR Thread networks with similarly unstable results. I thought Iād give it another try, but it seems the issues persist. I might end up buying another HomePod Mini or Apple TV instead of using my existing SkyConnect.
Do you know if anyone is actively working on these stability issues? I havenāt found any specific GitHub issues related to this, but navigating the HA project can be overwhelming without knowing exactly where to look. Thanks!
Wohnzimmer Lightstrip Thread Status became unavailable
08:07:35 - 16 minutes ago
Wohnzimmer Lightstrip Thread Status changed to Leader
08:04:04 - 19 minutes ago
Wohnzimmer Lightstrip Thread Status became unavailable
07:35:51 - 1 hour ago
Wohnzimmer Lightstrip Thread Status changed to Leader
07:34:04 - 1 hour ago
Wohnzimmer Lightstrip Thread Status became unavailable
07:05:39 - 1 hour ago
Wohnzimmer Lightstrip Thread Status changed to Leader
07:04:04 - 1 hour ago
Wohnzimmer Lightstrip Thread Status became unavailable
06:35:26 - 2 hours ago
Wohnzimmer Lightstrip Thread Status changed to Leader
06:34:04 - 2 hours ago
Wohnzimmer Lightstrip Thread Status became unavailable
06:06:45 - 2 hours ago
Wohnzimmer Lightstrip Thread Status changed to Leader
06:04:04 - 2 hours ago
EDIT: Thereās nothing in the logs for Home Assistant Core, Open Thread Border Router and Matter Server for this time frame.
EDIT2: Removing the device from HA, resetting and readding it caused the issues with this specific device to disappear. I noticed its Thread status changed from Leader to Router. So the problem might be caused if a Router device decides to take additional responsibilities as a Leader.
@agners Can you please help to figure out how to connect additional Thread Boarder Router to existing Thread Network. I have Home Assistant Yellow flashed with Thread only, OpenThread add-on and integration configured. Everything works as excepted. I bought SLZB-06M to extend my Thread network. I reflashed SLZB-06M with Thread only firmware. How do I add it to existing thread network? Do I need second instance of Home Assistant to install addon? Or is it possible to connect it to existing one somehow?
Was there an answer this question? I have a single SLZB-06M working correctly, but its range is insufficient to reach other Matter devicesā¦ adding a second, networked radio to the same Thread network would really solve my issueā¦
(although I guess I could buy a Tado Bridge-X and join it)
Ordinarily, if you just want to extend your network, you wouldnāt add another Border Router ā any line-powered Thread device will act as a repeater and increase your meshās range. The cheapest way is a $5 esp32-h2 dev module flashed with firmware as explained in this post, but any line-powered Thread device will work. I personally made a cheap repeater out of espressif zero code firmware.
I guess the exception is if you want to extend your network beyond the reach of the original mesh and donāt want (or canāt add) repeaters in between. You can get a standalone TBR like a GL-iNet GL-S200 or you can build one yourself with OTBR software coupled with an adapter. Ordinarily you would never run two OTBR containers on the same HA server (since they would be in the same place), but the SLZB-06M has a cool serial-over-IP feature allowing you to place it further away from the server running OTBR. Lots of niche cases there!
[ PS - I would add that, having two isolated (i.e. not in range of each other) TBRs means there is no reason/benefit for them to be the same network (name/credentials dataset) since you would know which mesh you are joining you just choose the one you want to use during commissioning. BUT the state of Thread UX is so dismal right now that having two mesh datasets is causing all sorts of confusion and itās not even clear if you CAN choose a mesh during commissioning. Given that reality, unless you have a separate mobile device to commission on each mesh, you may need to consolidate to a single mesh dataset which complicates things even MORE because vendors arenāt sharing datasets with each other yet. Currently (to my knowledge) only OTBR (being open) lets you modify its dataset to merge with another network. Hopefully this improves in the coming years. ]
TL;DR: use one TBR if you can, and repeaters to extend your mesh. If you must have two TBRs, make them the same vendor. If they must be different vendors, make sure the second one is OTBR so it can merge with the first to simplify commissioning. There are only niche cases where you might want to run two OTBRs on the same server, e.g. geographically sparse networks using serial-over-IP Thread adapters.
For what its worth, Iāll add that if the TBRs support a feature called TREL (and these TBRs can be put on the same Thread network), it theory at least, if a Thread network gets āpartitionedā, meaning it looses some connectivity within its mesh, and a TBR exist on each partition, then TREL is suppose to allow the partitions to be reconnected using the LAN connecting the TBRs.
In practice, Iām not so sure ā¦ I have 2 OTBRs running TRELL, but have found cases where one OTBR may loose connection with a device, while the other TBR still has connectivity (I havenāt actually dug into it enough to find out why). So Iām not so sure yet how well TREL really works.
But as mentioned by Peter, it will certainly help the mesh to have repeaters.
Is this possible yet? Looks like this PR was merged, however I canāt find any information about how to configure it or any supporting documentation mentioning it
I just glanced at the code [2025.1] on my running system and the changes are there.
It looks like you go to the UI->Integration->OTBR-> ADD SERVICE and you get a pop up asking for the URL to reach the OTBR which I presume is the additional instance.
Whether or not the Thread Integration can make use of it (like push preferred credentials), I donāt know.
Oh this is for the integration, I see.
Iām using the add-on, but canāt find a way to create an additional add-on instance. If thatās the intended behavior I donāt think this is possible in HA right now.
Does anyone know what did the testing environment for this PR look like?
Hope you donāt mind if I ask what is your use case for a second OTBR instance on the same machine?
Iām actually using a tcp/ip adapter connected over ethernet to ha which is running on a VM on a large virtualization host in the garage. I suppose running otbr outside of the ha add-on would make this possible?
Iām assuming that running another otbr instance is whatās necessary to run a second otbr adapter
I made another comment earlier in this thread sometime back to explain my use case, but the main thing Iām after here is network redundancy. My entire network is fully redundant with the exception of thread, zigbee, and Z-Wave
By this I think you mean OTBR ā tcp/ip ā Thread radio.
Just an FYI, the HA Matter/Thread developers have tested RCP over tcp/ip and have concluded it introduces too much variable delay and shouldnāt be used. From this page, scroll down and youāll see a warning about it.
Yea I saw that. I would imagine most of the problems arise from WiFi backhaul. Mine has been working great for 6 months via PoE. As things are right now, Iām happy with my current architecture, aside from the lack of redundancy
Hopefully a final question, is your PoE link running straight out of your HA machineās Ethernet port to the adapter, or are there multiple L2 switch hops or ever router hops along the path? I could see where the former is not a problem, but perhaps the latter (store and forward a packet) is a little more of a problem??
Thereās two physical switches and one virtual switch between HA and the radio
Thanks for the info
BTW, Here is a thread, where someone was able to hack a second AddOn instance of ZWaveJS-UI to their system. Maybe will work for OTBR AddOn ???
Oh cool, I was planning on running a second OTBR instance in an LXC container, this would be much more convenient. Iāll give it a try!