Errbot: получение ошибки yapsy при попытке настроить плагины через интерфейс командной строки
Моя цель - использовать puppet для инициализации экземпляра errbot, а также предварительно настроить плагины с помощью скрипта.
Я следовал их руководству пользователя, найденному здесь:
http://errbot.io/en/latest/user_guide/provisioning.html
Однако я продолжаю получать эту ошибку: "отклонено стратегией" SpecificBackendLocator ""
Вот мой вывод (моя переменная журнала в моем config.py установлена в DEBUG):
/opt/errbot$ /opt/errbot/bin/errbot --storage-get core
05:30:46 INFO errbot.cli Config check passed...
05:30:46 INFO errbot.specific_plugin_ma storage search paths {'/opt/errbot/lib/python3.4/site-packages/errbot/storage', '/opt/errbot/extra/devops', '/opt/errbot/extra/weatherbot'}
05:30:46 INFO errbot.specific_plugin_ma Found those plugings available:
05:30:46 INFO errbot.specific_plugin_ma Memory (/opt/errbot/lib/python3.4/site-packages/errbot/storage/memory.py)
05:30:46 INFO errbot.specific_plugin_ma Shelf (/opt/errbot/lib/python3.4/site-packages/errbot/storage/shelf.py)
05:30:46 INFO errbot.specific_plugin_ma DevOpsReactions (/opt/errbot/extra/devops/devops.py)
05:30:46 INFO errbot.specific_plugin_ma WeatherBot (/opt/errbot/extra/weatherbot/weatherBot.py)
05:30:46 INFO errbot.bootstrap Found Storage plugin: 'Memory'
Description: This is the storage plugin for an in-memory store (non-persistent).
05:30:46 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/storage/shelf.plug' rejected by strategy 'SpecificBackendLocator'
05:30:46 WARNING yapsy Plugin candidate '/opt/errbot/extra/devops/devops.plug' rejected by strategy 'SpecificBackendLocator'
05:30:46 WARNING yapsy Plugin candidate '/opt/errbot/extra/weatherbot/weatherbot.plug' rejected by strategy 'SpecificBackendLocator'
{}
Что я пробовал:
Я попытался использовать типы хранения "полка" и "память"
Я работал в обоих Python2,7 и 3,4
Я просмотрел все вопросы, связанные с errbot на этом форуме, я просмотрел репозиторий github, а также погуглил полученную ошибку.
Я не смог найти ничего, что помогло бы мне решить проблему.
Я не уверен, что это скорее проблема с модулем errbot, или он работает в моей среде python. Любой толчок в правильном направлении будет приветствоваться.
********** РЕДАКТИРОВАТЬ****************
За совет @ gbin я точно следовал его процессу:
vagrant@ops-hq-tools-chatops-app1:/opt/errbot/data$ sudo /opt/errbot/bin/errbot -c /opt/errbot/config.py -T
06:56:38 INFO errbot.cli Config check passed...
06:56:38 INFO errbot.cli Selected backend 'Text'.
06:56:38 INFO errbot.cli Checking for '/opt/errbot/data'...
06:56:38 INFO errbot.specific_plugin_ma storage search paths {'/opt/errbot/lib/python3.4/site-packages/errbot/storage', '/opt/errbot/extra/devops'}
06:56:38 INFO errbot.specific_plugin_ma Found those plugings available:
06:56:38 INFO errbot.specific_plugin_ma Memory (/opt/errbot/lib/python3.4/site-packages/errbot/storage/memory.py)
06:56:38 INFO errbot.specific_plugin_ma Shelf (/opt/errbot/lib/python3.4/site-packages/errbot/storage/shelf.py)
06:56:38 INFO errbot.specific_plugin_ma DevOpsReactions (/opt/errbot/extra/devops/devops.py)
06:56:38 INFO errbot.bootstrap Found Storage plugin: 'Shelf'
Description: This is the storage plugin for the traditional shelf store for errbot.
06:56:38 DEBUG errbot.specific_plugin_ma Refilter the plugins...
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/storage/memory.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/extra/devops/devops.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 DEBUG errbot.specific_plugin_ma Load the one remaining...
06:56:38 DEBUG errbot.specific_plugin_ma Class to load ShelfStoragePlugin
06:56:38 DEBUG errbot.storage Opening storage 'repomgr'
06:56:38 DEBUG errbot.storage.shelf Open shelf storage /opt/errbot/data/repomgr.db
06:56:38 DEBUG errbot.storage Opening storage 'core'
06:56:38 DEBUG errbot.storage.shelf Open shelf storage /opt/errbot/data/core.db
06:56:38 INFO errbot.specific_plugin_ma backends search paths {'/opt/errbot/lib/python3.4/site-packages/errbot/backends'}
06:56:38 INFO errbot.specific_plugin_ma Found those plugings available:
06:56:38 INFO errbot.specific_plugin_ma Test (/opt/errbot/lib/python3.4/site-packages/errbot/backends/test.py)
06:56:38 INFO errbot.specific_plugin_ma Graphic (/opt/errbot/lib/python3.4/site-packages/errbot/backends/graphic.py)
06:56:38 INFO errbot.specific_plugin_ma Text (/opt/errbot/lib/python3.4/site-packages/errbot/backends/text.py)
06:56:38 INFO errbot.specific_plugin_ma Telegram (/opt/errbot/lib/python3.4/site-packages/errbot/backends/telegram_messenger.py)
06:56:38 INFO errbot.specific_plugin_ma XMPP (/opt/errbot/lib/python3.4/site-packages/errbot/backends/xmpp.py)
06:56:38 INFO errbot.specific_plugin_ma Slack (/opt/errbot/lib/python3.4/site-packages/errbot/backends/slack.py)
06:56:38 INFO errbot.specific_plugin_ma Hipchat (/opt/errbot/lib/python3.4/site-packages/errbot/backends/hipchat.py)
06:56:38 INFO errbot.specific_plugin_ma Null (/opt/errbot/lib/python3.4/site-packages/errbot/backends/null.py)
06:56:38 INFO errbot.specific_plugin_ma IRC (/opt/errbot/lib/python3.4/site-packages/errbot/backends/irc.py)
06:56:38 INFO errbot.bootstrap Found Backend plugin: 'Text'
Description: This is the text backend for Err.
06:56:38 DEBUG errbot.specific_plugin_ma Refilter the plugins...
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/backends/test.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/backends/graphic.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/backends/telegram_messenger.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/backends/xmpp.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/backends/slack.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/backends/hipchat.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/backends/null.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/backends/irc.plug' rejected by strategy 'SpecificBackendLocator'
06:56:38 DEBUG errbot.specific_plugin_ma Load the one remaining...
06:56:38 DEBUG errbot.specific_plugin_ma Class to load TextBackend
06:56:38 DEBUG errbot.core ErrBot init.
06:56:38 DEBUG errbot.backends.base Backend init.
06:56:38 DEBUG errbot.core created a thread pool of size 10.
06:56:38 DEBUG errbot.backends.text Text Backend Init.
06:56:38 DEBUG MARKDOWN Successfuly imported extension module "markdown.extensions.smart_strong".
06:56:38 DEBUG MARKDOWN Successfully loaded extension "markdown.extensions.smart_strong.SmartEmphasisExtension".
06:56:38 DEBUG MARKDOWN Successfuly imported extension module "markdown.extensions.fenced_code".
06:56:38 DEBUG MARKDOWN Successfully loaded extension "markdown.extensions.fenced_code.FencedCodeExtension".
06:56:38 DEBUG MARKDOWN Successfuly imported extension module "markdown.extensions.footnotes".
06:56:38 DEBUG MARKDOWN Successfully loaded extension "markdown.extensions.footnotes.FootnoteExtension".
06:56:38 DEBUG MARKDOWN Successfuly imported extension module "markdown.extensions.attr_list".
06:56:38 DEBUG MARKDOWN Successfully loaded extension "markdown.extensions.attr_list.AttrListExtension".
06:56:38 DEBUG MARKDOWN Successfuly imported extension module "markdown.extensions.def_list".
06:56:38 DEBUG MARKDOWN Successfully loaded extension "markdown.extensions.def_list.DefListExtension".
06:56:38 DEBUG MARKDOWN Successfuly imported extension module "markdown.extensions.tables".
06:56:38 DEBUG MARKDOWN Successfully loaded extension "markdown.extensions.tables.TableExtension".
06:56:38 DEBUG MARKDOWN Successfuly imported extension module "markdown.extensions.abbr".
06:56:38 DEBUG MARKDOWN Successfully loaded extension "markdown.extensions.abbr.AbbrExtension".
06:56:38 DEBUG MARKDOWN Successfully loaded extension "markdown.extensions.extra.ExtraExtension".
06:56:38 DEBUG MARKDOWN Successfully loaded extension "errbot.rendering.ansiext.AnsiExtension".
06:56:38 DEBUG errbot.core Initializing backend storage
06:56:38 DEBUG errbot.storage Opening storage 'text_backend'
06:56:38 DEBUG errbot.storage.shelf Open shelf storage /opt/errbot/data/text_backend.db
06:56:38 DEBUG errbot.plugin_manager All plugin roots:
06:56:38 DEBUG errbot.plugin_manager -> /opt/errbot/lib/python3.4/site-packages/errbot/core_plugins
06:56:38 DEBUG errbot.plugin_manager Add /opt/errbot/lib/python3.4/site-packages/errbot/core_plugins to sys.path
06:56:38 DEBUG errbot.plugin_manager -> /opt/errbot/extra/devops
06:56:38 DEBUG errbot.plugin_manager /opt/errbot/lib/python3.4/site-packages/errbot/core_plugins has no requirements.txt file
06:56:38 DEBUG errbot.plugin_manager /opt/errbot/extra/devops has no requirements.txt file
06:56:38 INFO errbot webhooks: Flag to bind /echo to echo
06:56:38 DEBUG errbot.bootstrap Start serving commands from the text backend
>>> !plugin config Webserver
Default configuration for this plugin (you can copy and paste this directly as a command):
!plugin config Webserver
{'HOST': '0.0.0.0',
'PORT': 3141,
'SSL': {'certificate': '',
'enabled': False,
'host': '0.0.0.0',
'key': '',
'port': 3142}}
Current configuration:
!plugin config Webserver
{'HOST': '0.0.0.0',
'PORT': 3141,
'SSL': {'certificate': '',
'enabled': False,
'host': '0.0.0.0',
'key': '',
'port': 3142}}
>>> !plugin config Webserver {'HOST': '0.0.0.0', 'PORT': 3141, 'SSL': {'certificate': '', 'enabled': False, 'host': '0.0.0.0', 'key': '', 'port': 3142}}
Plugin configuration done.
Пока все хорошо, тогда я должен выполнить следующую команду с sudo:
/opt/errbot/bin/errbot -c /opt/errbot/config.py --storage-get core
07:01:19 INFO errbot.cli Config check passed...
07:01:19 INFO errbot.specific_plugin_ma storage search paths {'/opt/errbot/extra/devops', '/opt/errbot/lib/python3.4/site-packages/errbot/storage'}
07:01:19 INFO errbot.specific_plugin_ma Found those plugings available:
07:01:19 INFO errbot.specific_plugin_ma DevOpsReactions (/opt/errbot/extra/devops/devops.py)
07:01:19 INFO errbot.specific_plugin_ma Memory (/opt/errbot/lib/python3.4/site-packages/errbot/storage/memory.py)
07:01:19 INFO errbot.specific_plugin_ma Shelf (/opt/errbot/lib/python3.4/site-packages/errbot/storage/shelf.py)
07:01:19 INFO errbot.bootstrap Found Storage plugin: 'Shelf'
Description: This is the storage plugin for the traditional shelf store for errbot.
07:01:19 WARNING yapsy Plugin candidate '/opt/errbot/extra/devops/devops.plug' rejected by strategy 'SpecificBackendLocator'
07:01:19 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/storage/memory.plug' rejected by strategy 'SpecificBackendLocator'
{'configs': {'Webserver': {'PORT': 3141, 'HOST': '0.0.0.0', 'SSL': {'host': '0.0.0.0', 'key': '', 'enabled': False, 'port': 3142, 'certificate': ''}}, 'giphy': {'API_KEY': 'test'}, 'WeatherBot': None}}
Таким образом, функция --storage-get работает, как и ожидалось. Однако, когда я пытаюсь --storage-set/merge:
sudo echo "{'configs': {'Webserver': {'PORT': 9999}}}" | /opt/errbot/bin/errbot -c /opt/errbot/config.py --storage-merge core
07:02:46 INFO errbot.cli Config check passed...
07:02:46 INFO errbot.specific_plugin_ma storage search paths {'/opt/errbot/lib/python3.4/site-packages/errbot/storage', '/opt/errbot/extra/devops'}
07:02:46 INFO errbot.specific_plugin_ma Found those plugings available:
07:02:46 INFO errbot.specific_plugin_ma Memory (/opt/errbot/lib/python3.4/site-packages/errbot/storage/memory.py)
07:02:46 INFO errbot.specific_plugin_ma Shelf (/opt/errbot/lib/python3.4/site-packages/errbot/storage/shelf.py)
07:02:46 INFO errbot.specific_plugin_ma DevOpsReactions (/opt/errbot/extra/devops/devops.py)
07:02:46 INFO errbot.bootstrap Found Storage plugin: 'Shelf'
Description: This is the storage plugin for the traditional shelf store for errbot.
07:02:46 WARNING yapsy Plugin candidate '/opt/errbot/lib/python3.4/site-packages/errbot/storage/memory.plug' rejected by strategy 'SpecificBackendLocator'
07:02:46 WARNING yapsy Plugin candidate '/opt/errbot/extra/devops/devops.plug' rejected by strategy 'SpecificBackendLocator'
Storage does not appear to have been opened yet
Я получаю эту ошибку "Хранилище еще не открыто.
Я нашел эту ссылку, погуглив ошибку:
http://errbot.io/en/latest/_modules/errbot/storage.html
но у меня возникают проблемы с пониманием того, что мне нужно изменить, чтобы я мог объединить или установить значения конфигурации.
2 ответа
rejected by strategy 'SpecificBackendLocator'
это вводящее в заблуждение предупреждение от yapsy о том, что плагин - это не то, на что он смотрит в данный момент, а циклы над всеми плагинами, это нормальное поведение
Запись, которую вы получаете за core
является {}
, пусто. Просто ваш экземпляр Errbot еще ничего там не хранит.
Например, проверьте этот сеанс:
(errbot)mymachine ➜ errbot (master) errbot -T
08:36:27 INFO errbot.cli Config check passed...
08:36:27 INFO errbot.cli Selected backend 'Text'.
08:36:27 INFO errbot.cli Checking for '../errbot-data'...
08:36:27 INFO errbot.specific_plugin_ma storage search paths {'/home/gbinet/projects/errbot/errbot/storage'}
08:36:27 INFO errbot.specific_plugin_ma Found those plugings available:
08:36:27 INFO errbot.specific_plugin_ma Shelf (/home/gbinet/projects/errbot/errbot/storage/shelf.py)
08:36:27 INFO errbot.specific_plugin_ma Memory (/home/gbinet/projects/errbot/errbot/storage/memory.py)
08:36:27 INFO errbot.bootstrap Found Storage plugin: 'Shelf'
Description: This is the storage plugin for the traditional shelf store for errbot.
08:36:27 WARNING yapsy Plugin candidate '/home/gbinet/projects/errbot/errbot/storage/memory.plug' rejected by strategy 'SpecificBackendLocator'
08:36:27 INFO errbot.specific_plugin_ma backends search paths {'/home/gbinet/projects/errbot/errbot/backends'}
[...]
08:36:27 INFO errbot.bootstrap Found Backend plugin: 'Text'
Description: This is the text backend for Err.
08:36:27 WARNING yapsy Plugin candidate '/home/gbinet/projects/errbot/errbot/backends/irc.plug' rejected by strategy 'SpecificBackendLocator'
[...]
>>> !plugin config Webserver
Default configuration for this plugin (you can copy and paste this directly as a command):
!plugin config Webserver
{'HOST': '0.0.0.0',
'PORT': 3141,
'SSL': {'certificate': '',
'enabled': False,
'host': '0.0.0.0',
'key': '',
'port': 3142}}
>>> !plugin config Webserver {'HOST': '0.0.0.0', 'PORT': 3141, 'SSL': {'certificate': '', 'enabled': False, 'host': '0.0.0.0', 'key': '', 'port': 3142}}
Plugin configuration done.
>>> ^C
Здесь хранится конфиг для плагина "Веб-сервер", и вы можете увидеть его, когда сбросите все конфиги из командной строки:
(errbot)mymachine ➜ errbot (master) errbot --storage-get core
08:37:54 INFO errbot.cli Config check passed...
08:37:54 INFO errbot.specific_plugin_ma storage search paths {'/home/gbinet/projects/errbot/errbot/storage'}
08:37:54 INFO errbot.specific_plugin_ma Found those plugings available:
08:37:54 INFO errbot.specific_plugin_ma Shelf (/home/gbinet/projects/errbot/errbot/storage/shelf.py)
08:37:54 INFO errbot.specific_plugin_ma Memory (/home/gbinet/projects/errbot/errbot/storage/memory.py)
08:37:54 INFO errbot.bootstrap Found Storage plugin: 'Shelf'
Description: This is the storage plugin for the traditional shelf store for errbot.
08:37:54 WARNING yapsy Plugin candidate '/home/gbinet/projects/errbot/errbot/storage/memory.plug' rejected by strategy 'SpecificBackendLocator'
{'configs': {'Webserver': {'PORT': 3141, 'SSL': {'enabled': False, 'port': 3142, 'key': '', 'host': '0.0.0.0', 'certificate': ''}, 'HOST': '0.0.0.0'}}}
Я сделал именно то, что вы сделали, и это работает для меня.
Есть ли что-то особенное в вашей конфигурации?
(errbot)mymachine ➜ errbot (master) echo "{'configs': {'Webserver': {'PORT': 9999}}}" | errbot --storage-merge core <<<
14:22:12 INFO errbot.cli Config check passed...
14:22:12 INFO errbot.specific_plugin_ma storage search paths {'/home/gbinet/projects/errbot/errbot/storage'}
14:22:12 INFO errbot.specific_plugin_ma Found those plugings available:
14:22:12 INFO errbot.specific_plugin_ma Shelf (/home/gbinet/projects/errbot/errbot/storage/shelf.py)
14:22:12 INFO errbot.specific_plugin_ma Memory (/home/gbinet/projects/errbot/errbot/storage/memory.py)
14:22:12 INFO errbot.bootstrap Found Storage plugin: 'Shelf'
Description: This is the storage plugin for the traditional shelf store for errbot.
14:22:12 WARNING yapsy Plugin candidate '/home/gbinet/projects/errbot/errbot/storage/memory.plug' rejected by strategy 'SpecificBackendLocator'
(errbot)mymachine ➜ errbot (master) errbot --storage-get core
14:22:57 INFO errbot.cli Config check passed...
14:22:57 INFO errbot.specific_plugin_ma storage search paths {'/home/gbinet/projects/errbot/errbot/storage'}
14:22:57 INFO errbot.specific_plugin_ma Found those plugings available:
14:22:57 INFO errbot.specific_plugin_ma Shelf (/home/gbinet/projects/errbot/errbot/storage/shelf.py)
14:22:57 INFO errbot.specific_plugin_ma Memory (/home/gbinet/projects/errbot/errbot/storage/memory.py)
14:22:57 INFO errbot.bootstrap Found Storage plugin: 'Shelf'
Description: This is the storage plugin for the traditional shelf store for errbot.
14:22:57 WARNING yapsy Plugin candidate '/home/gbinet/projects/errbot/errbot/storage/memory.plug' rejected by strategy 'SpecificBackendLocator'
{'configs': {'Webserver': {'PORT': 9999}}}