Крестовина Thruway работник падает

У меня есть сервер Crossbar.io с работниками PHP Thruway. Недавно я начал получать следующую ошибку. Это происходит примерно раз в день сейчас:

2016-04-17T21:08:12+0000 [Router       9572] Unable to format event {'log_logger': <Logger 'crossbar.router.protocol.WampWebSocketServerProtocol'>, 'log_time': 1460927292.17918, 'log_source': None, 'log_format': 'Traceback (most recent call last):\n  File "/usr/local/lib/python2.7/site-packages/autobahn/wamp/websocket.py", line 88, in onMessage\n    for msg in self._serializer.unserialize(payload, isBinary):\n  File "/usr/local/lib/python2.7/site-packages/autobahn/wamp/serializer.py", line 106, in unserialize\n    raise ProtocolError("invalid serialization of WAMP message ({0})".format(e))\nProtocolError: invalid serialization of WAMP message (Expected object or value)\n'}: tuple index out of range
2016-04-17T21:08:15+0000 [Guest        9583] The connected has closed with reason: close
2016-04-17T21:08:19+0000 [Guest        9583] PHP Fatal error:  Call to a member function call() on null in /var/www/html/pickupServer/vendor/voryx/thruway/src/Thruway/ClientSession.php on line 106
2016-04-17T21:08:19+0000 [Guest        9583] Fatal error: Call to a member function call() on null in /var/www/html/pickupServer/vendor/voryx/thruway/src/Thruway/ClientSession.php on line 106
2016-04-17T21:08:19+0000 [Controller   9565] Guest worker2 exited with error A process has ended with a probable error condition: process ended with exit code 255.

Кто-нибудь знает, чтобы предотвратить это?

Как я автоматически перезагружаю работника, если он выходит из строя, как в этом случае?

1 ответ

Я решил это в linux с MONIT, проверяя процесс crossbar-controler и добавляя следующую строку:

если дети < 3, то перезагрузите

3 - это число дочерних процессов, которые контролер кросс-панели имеет в моей среде. Если какой-либо из них выходит, перекладина перезагружается и уведомляет меня. Вы должны проверить количество дочерних процессов, которые вы используете, используя:

Состояние перекладины службы sudo.

Это решает ошибку выхода работника, но со стоимостью перезапуска контроллера поперечины. Я убежден, что это должен быть перекрестный / сквозной способ решения проблемы. Идеальный способ - попытаться поймать все возможные ошибки php, чтобы предотвратить фатальные выходы работника.

Спасибо

Другие вопросы по тегам