Любая попытка запустить сервисы nova compute завершается ошибкой. HypervisorUnavailable: Connection to the hypervisor is broken on host:
Журнал трассировки следующий (взят из /var/log/nova/nova-compute.log
)
AUDIT nova.service [-] Starting compute node (version 2014.1.1)
ERROR nova.virt.libvirt.driver [-] Connection to libvirt failed: Failed to connect socket to '/var/run/libvirt/libvirt-sock': No such file or directory
TRACE nova.virt.libvirt.driver Traceback (most recent call last):
TRACE nova.virt.libvirt.driver File "/usr/lib/python2.7/dist-packages/nova/virt/libvirt/driver.py", line 787, in _connect
TRACE nova.virt.libvirt.driver libvirt.openAuth, uri, auth, flags)
TRACE nova.virt.libvirt.driver File "/usr/lib/python2.7/dist-packages/eventlet/tpool.py", line 139, in proxy_call
TRACE nova.virt.libvirt.driver rv = execute(f,*args,**kwargs)
TRACE nova.virt.libvirt.driver File "/usr/lib/python2.7/dist-packages/eventlet/tpool.py", line 77, in tworker
TRACE nova.virt.libvirt.driver rv = meth(*args,**kwargs)
TRACE nova.virt.libvirt.driver File "/usr/lib/python2.7/dist-packages/libvirt.py", line 105, in openAuth
TRACE nova.virt.libvirt.driver if ret is None:raise libvirtError('virConnectOpenAuth() failed')
TRACE nova.virt.libvirt.driver libvirtError: Failed to connect socket to '/var/run/libvirt/libvirt-sock': No such file or directory
TRACE nova.virt.libvirt.driver
ERROR nova.openstack.common.threadgroup [-] Connection to the hypervisor is broken on host: <HOST_NAME>
TRACE nova.openstack.common.threadgroup Traceback (most recent call last):
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/openstack/common/threadgroup.py", line 117, in wait
TRACE nova.openstack.common.threadgroup x.wait()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/openstack/common/threadgroup.py", line 49, in wait
TRACE nova.openstack.common.threadgroup return self.thread.wait()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/eventlet/greenthread.py", line 168, in wait
TRACE nova.openstack.common.threadgroup return self._exit_event.wait()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/eventlet/event.py", line 116, in wait
TRACE nova.openstack.common.threadgroup return hubs.get_hub().switch()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/eventlet/hubs/hub.py", line 187, in switch
TRACE nova.openstack.common.threadgroup return self.greenlet.switch()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/eventlet/greenthread.py", line 194, in main
TRACE nova.openstack.common.threadgroup result = function(*args, **kwargs)
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/openstack/common/service.py", line 483, in run_service
TRACE nova.openstack.common.threadgroup service.start()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/service.py", line 163, in start
TRACE nova.openstack.common.threadgroup self.manager.init_host()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/compute/manager.py", line 1006, in init_host
TRACE nova.openstack.common.threadgroup self.driver.init_host(host=self.host)
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/virt/libvirt/driver.py", line 656, in init_host
TRACE nova.openstack.common.threadgroup self._do_quality_warnings()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/virt/libvirt/driver.py", line 639, in _do_quality_warnings
TRACE nova.openstack.common.threadgroup caps = self.get_host_capabilities()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/virt/libvirt/driver.py", line 2849, in get_host_capabilities
TRACE nova.openstack.common.threadgroup xmlstr = self._conn.getCapabilities()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/virt/libvirt/driver.py", line 721, in _get_connection
TRACE nova.openstack.common.threadgroup wrapped_conn = self._get_new_connection()
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/virt/libvirt/driver.py", line 674, in _get_new_connection
TRACE nova.openstack.common.threadgroup wrapped_conn = self._connect(self.uri(), self.read_only)
TRACE nova.openstack.common.threadgroup File "/usr/lib/python2.7/dist-packages/nova/virt/libvirt/driver.py", line 796, in _connect
TRACE nova.openstack.common.threadgroup raise exception.HypervisorUnavailable(host=CONF.host)
TRACE nova.openstack.common.threadgroup HypervisorUnavailable: Connection to the hypervisor is broken on host: <HOST_NAME>
Никакой другой файл журнала не указывает на ошибку syslog
, dmesg
и /var/log/libvirt/libvirtd.log
не показывает никаких проблем
Конфигурация libvirt (/etc/libvirt/libvirtd.conf
) был настроен для регистрации ошибок log_outputs="3:syslog:libvirtd"
До появления ошибки узел работал без сбоев, никаких изменений не производилось.
В моем случае я переустановил libvirt и связанные с ним пакеты без перезапуска. libvirtd
. Таким образом, ошибка была устранена с помощью следующих трех команд:
systemctl stop libvirtd
systemctl start libvirtd
systemctl status libvirtd
Похоже, это была неправильная конфигурация libvirt
. Вкратце проблема заключалась в том, что libvirtd
не начинался с --listen
flag, и поэтому он не создавал соответствующий файл sock, который ищет служба nova.
См. Мои соответствующие ответ спросите ubuntu о том, как настроить libvirt в режиме прослушивания.
У меня был похожий случай прошлой ночью, когда я пытался перезапустить nova-compute
служба . В предоставленном вами LPG мы можем se3 следующие строки
Не удалось подключить сокет к '/ var / run / libvirt / libvirt-sock': нет такого файла или каталога TRACE nova.virt.libvirt.driver "
Таким образом, мы можем знать, что проблема связана с libvirtd
сервис не работает.
В моем случае я проверил статус libvirtd
сервис, чтобы выяснить, почему он не работает, а затем я попытался перезапустить его, как показано ниже
Я много гуглил о проблеме (g-io-error-quark, 1) выше. Но все результаты касаются проблемы / etc / fstab.
В моем случае я попытался использовать libvirtd -l
команда, чтобы получить несколько советов
Наконец я узнал, что это! Проблема в /var/run
и это ссылка на путь / запуск, и ссылка не работает. Я сбросил ссылку на / run, а затем перезапустил libvirtd
обслуживание успешно.
Я надеюсь, что это сработает для вас.