this post was submitted on 01 Oct 2023
21 points (95.7% liked)

homeassistant

12102 readers
14 users here now

Home Assistant is open source home automation that puts local control and privacy first. Powered by a worldwide community of tinkerers and DIY enthusiasts. Perfect to run on a Raspberry Pi or a local server. Available for free at home-assistant.io

founded 1 year ago
MODERATORS
 

I'm using a ZigBee button to call an automation which notifies via Pushover and Alexa. Works fine.

I'd like to reduce latency and use a physical button. I can use a Pi, ESP32 or similar to respond to a closure and tell HA.

What's the lowest latency input to HA? My MQTT server is separate so I'm thinking an HTTP post direct into HA might be best.

Is there anything faster? HTTP is fast enough in my testing, it's an experiment as much as anything else.

top 14 comments
sorted by: hot top controversial new old
[–] PHLAK@lemmy.world 9 points 1 year ago* (last edited 1 year ago) (1 children)

If you can hard wire an ESP32 via Ethernet that would probably be best. You could also get better latency with an ESP32 over WiFi. However, a ZigBee button should be pretty low latency already.

Anecdotally I get perceptibly instant response from an ESP32 over WiFi.

[–] Sim 1 points 1 year ago (1 children)

Perceptibly instant is fast enough for me :)

What's the method you're using to communicate with HA?

[–] StandingCat@lemmy.world 1 points 1 year ago

Im guessing the latency here isnt zigbee, but the two cloud components that follow the button.

[–] deafboy@lemmy.world 6 points 1 year ago* (last edited 1 year ago) (1 children)

All my zigbee devices respond pretty much instantly. And that's a 2 way trip. Button to HA, HA to lightswitch.

What happens when you trigger the same action from the dashboard? Is it faster?

[–] Sim 1 points 1 year ago (1 children)

It's probably marginally faster from the dashboard. This isn't only about the ZigBee delay though - it's really perfectly OK. Reducing latency is as much for the fun of it than anything else. I'm interested in knowing what the fastest possible input method is.

[–] CmdrShepard@lemmy.one 1 points 1 year ago

What about binding the trigger to the device using something like Zigbee2MQTT so that it doesn't have to pass through HA at all?

[–] RegalPotoo@lemmy.world 4 points 1 year ago (1 children)

Theoretically, MQTT would be faster than HTTP; with MQTT the clients all maintain a persistent connection to the server, so sending a message is just a case of sending another packet on the existing connection, where as HTTP in the worst case would require a DNS lookup, TCP connection setup and TLS handshake before the button press could be reported.

The downside of a persistent connection is you have to maintain a persistent connection - not an issue if you are hardwired, but for things in batteries it probably isn't practical

[–] Sim 1 points 1 year ago (1 children)

I have a wired device sending HTTP POST updates very regularly (often more than one per second) and if I watch those arrive, they appear almost instantaneous. If the sending device used IP (or, more likely, had cached the lookup) I guess that would be fast too.

Good point about the MQTT persistence, cheers.

[–] RegalPotoo@lemmy.world 1 points 1 year ago

Practically it doesn't make any real difference - unless your network is ancient/massively overloaded/completely screwed or your client device is low power enough to struggle with TLS the whole connection setup process is only going to take ~100ms at most

[–] nottelling@lemmy.world 3 points 1 year ago (1 children)

OP asks for "lowest latency" but HTTP is fast enough, and later in the thread says "perceptibly instant" is the goal. HTTP is going to be your slowest option, almost certainly, but even the slowest solution is "instant".

What exactly are you trying to do, OP?

(Esphome seems like the answer you're looking for. It's faster than MQTT and you can program parts of the automation and service management in the ESP hardware. RF is probably the only way to go faster.)

[–] Sim 1 points 1 year ago

I'm interested in what other people have found to be the fastest way to deliver events into HA. It's been a useful thread.

[–] peregus@lemmy.world 2 points 1 year ago (1 children)

I don't think that MQTT could add any perceptible latency. Maybe is the button itself that adds it. Isn't the button able to recognize multiple pushes? If yes, there lies the delay: the button waits for a second push and if it doesn't arrives, it sends out the command to the coordinator. What kind of ZigBee button are you using?

[–] Sim 1 points 1 year ago

That's a good point; the button does support double push, I might be able to disable that. It's some old unit I picked up for next to nothing, I have some Aqura buttons about to try.

[–] pajn@lemmy.blahaj.zone 2 points 1 year ago

Zigbee is for this usecase instant and definitely faster than any ESP wifi based solution. Your slowness here isn't for reaching HA, it's HA itself and primarily pushover and Alexa. What is it you are trying to do? For anything that should feel instant, getting rid of pushover and Alexa will be crucial.