Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

mqtt-squeeze: survive telnet connection drops / LMS restarts #57

Open
declension opened this issue Jun 24, 2018 · 3 comments
Open

mqtt-squeeze: survive telnet connection drops / LMS restarts #57

declension opened this issue Jun 24, 2018 · 3 comments

Comments

@declension
Copy link
Owner

declension commented Jun 24, 2018

In mqttsqueeze, currently we get an EOFError if the persistent CLI connection is interrupted. Better if it wrapped this and restarted somehow (probably likewise with the MQTT connection though the library hopefully handles this itself a bit)

Example Logs

  File "./main.py", line 74, in <module>                                                                                                      
    client.loop_forever(retry_first_connection=True)                                                                                          
  File "/volume1/@appstore/py3k/usr/local/lib/python3.5/site-packages/paho/mqtt/client.py", line 1481, in loop_forever                        
    rc = self.loop(timeout, max_packets)                                                                                                      
  File "/volume1/@appstore/py3k/usr/local/lib/python3.5/site-packages/paho/mqtt/client.py", line 1003, in loop                                
    rc = self.loop_read(max_packets)                                                                                                          
  File "/volume1/@appstore/py3k/usr/local/lib/python3.5/site-packages/paho/mqtt/client.py", line 1284, in loop_read                           
    rc = self._packet_read()                                                                                                                  
  File "/volume1/@appstore/py3k/usr/local/lib/python3.5/site-packages/paho/mqtt/client.py", line 1849, in _packet_read                        
    rc = self._packet_handle()                                                                                                                
  File "/volume1/@appstore/py3k/usr/local/lib/python3.5/site-packages/paho/mqtt/client.py", line 2305, in _packet_handle                      
    return self._handle_publish()                                                                                                             
  File "/volume1/@appstore/py3k/usr/local/lib/python3.5/site-packages/paho/mqtt/client.py", line 2504, in _handle_publish                     
    self._handle_on_message(message)                                                                                                          
  File "/volume1/@appstore/py3k/usr/local/lib/python3.5/site-packages/paho/mqtt/client.py", line 2647, in _handle_on_message                  
    self.on_message(self, self._userdata, message)                                                                                            
  File "./main.py", line 40, in on_message                                                                                                    
    resp_lines.append(telnet.read_until(b'\n').strip())                                                                                       
  File "/volume1/@appstore/py3k/usr/local/lib/python3.5/telnetlib.py", line 327, in read_until                                                
    return self.read_very_lazy()                                                                                                              
  File "/volume1/@appstore/py3k/usr/local/lib/python3.5/telnetlib.py", line 403, in read_very_lazy                                            
    raise EOFError('telnet connection closed')                                                                                                
EOFError: telnet connection closed                                                                                                            
Disconnecting broker on *****.*****.amazonaws.com:8883                                                                        
Underlying socket connection gone (_ssl.c:1770)
@declension
Copy link
Owner Author

To a large extent this is solved by the service wrappers, e.g. Upstart

@declension
Copy link
Owner Author

System wrapper scripts documented and working for systemd and Upstart, and won't get better than this, so closing

@declension declension reopened this Mar 10, 2019
@declension
Copy link
Owner Author

No, this is still a problem, as the exception is actually caught within the app, e.g. after an LMS restart:

2019-03-10T00:16:12+0000 [ERROR  ] Caught exception in on_message: telnet connection closed

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

No branches or pull requests

1 participant