MQTT Gateway - disconnects after a day


We have an MQTT gateway and two wireless transmitters in our setup:

By changing the stage of each input on either transmitter we receive an MQTT message properly. However, after a day of letting the system run, we no longer get any MQTT messages from either transmitter. The LED status on the gateway is still green but it needs a restart to work properly again. All of these devices are powered up with power supplies.

How can we make the connection more stable?


What MQTT Broker are you connecting The MQTT Gateway to?

It’s connected to a Mosquitto MQTT installed on a Raspberry Pi in the local area network.

I have another customer who has reported this same issue but he was connecting The MQTT Gateway to Ubidots. I am going to look into this over the next couple of days and see if I can replicate the problem. It’s extremely difficult to troubleshoot something when it takes a long time for the problem to occur in use so it may take me a few days. When I do resolve the problem it will be possible for you to update the firmware on your MQTT Gateway without returning it, I’ll provide instructions on that procedure when I have the issue resolved.

Thank you,
Travis Elliott

I had another user update his gateway with the latest firmware and it corrected his problem.

You could try updating your MQTT Gateway module to the latest firmware though. Updating the firmware on the module requires this script:

The guide for it can be found here:

Great, thanks for this. I’ll try updating the firmware to see if that solves the problem.


We were trying to upgrade the firmware but looks like there is a SSL certificate issue. Here’s the terminal log:

Scanning for Serial Ports
Please wait for the scan to complete
Serial Port Options:
[1]: /dev/cu.Bluetooth-Incoming-Port
[2]: /dev/cu.SLAB_USBtoUART

Please enter the number of the desired Serial Port above: 2
Firmware Choices:
[1]: WiFi AWS Gateway
[2]: WiFi Azure Gateway
[3]: WiFi MQTT Gateway
[4]: WiFi Google IoT Gateway
[5]: Mega Modem
[6]: Cellular MQTT Gateway

Please enter the number of the desired firmware: 3
Traceback (most recent call last):
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/urllib/”, line 1317, in do_open
h.request(req.get_method(), req.selector,, headers,
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/http/”, line 1230, in request
self._send_request(method, url, body, headers, encode_chunked)
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/http/”, line 1276, in _send_request
self.endheaders(body, encode_chunked=encode_chunked)
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/http/”, line 1225, in endheaders
self._send_output(message_body, encode_chunked=encode_chunked)
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/http/”, line 1004, in _send_output
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/http/”, line 944, in send
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/http/”, line 1399, in connect
self.sock = self._context.wrap_socket(self.sock,
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/”, line 500, in wrap_socket
return self.sslsocket_class._create(
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/”, line 1040, in _create
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/”, line 1309, in do_handshake
ssl.SSLCertVerificationError: [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1108)

During handling of the above exception, another exception occurred:

Traceback (most recent call last):
File “”, line 179, in
firmware_file = urllib.request.urlretrieve(str(firmware.get(‘firmware’)), ‘./firmware.bin’)
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/urllib/”, line 247, in urlretrieve
with contextlib.closing(urlopen(url, data)) as fp:
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/urllib/”, line 222, in urlopen
return, data, timeout)
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/urllib/”, line 525, in open
response = self._open(req, data)
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/urllib/”, line 542, in _open
result = self._call_chain(self.handle_open, protocol, protocol +
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/urllib/”, line 502, in _call_chain
result = func(*args)
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/urllib/”, line 1360, in https_open
return self.do_open(http.client.HTTPSConnection, req,
File “/Library/Frameworks/Python.framework/Versions/3.8/lib/python3.8/urllib/”, line 1320, in do_open
raise URLError(err)
urllib.error.URLError: <urlopen error [SSL: CERTIFICATE_VERIFY_FAILED] certificate verify failed: unable to get local issuer certificate (_ssl.c:1108)>

@jacob can you take a look at this?

I double checked permissions on the server files and they look correct.

I’d chalk this up to a local computer certificate issue. Either not sufficient permissions to access the appropriate certs via Python or some other arcane issue with CA files.

Try the tips on this stack overflow and try and manually pull in certs:

Let me know if that doesn’t solve the issue.