Dbus_bus_request_name(): Соединениям запрещено владеть услугой

Я построил корневую файловую систему на руке. Он должен запускать dbus-демон и avahi-daemon, но когда я пытаюсь запустить avahi-daemon

$ dbus-daemon --system
$ avahi-daemon

Я получаю это сообщение:

Found user 'avahi' (UID 4) and group 'avahi' (GID 4).
Successfully dropped root privileges.
avahi-daemon 0.6.28 starting up.
WARNING: No NSS support for mDNS detected, consider installing nss-mdns! 
dbus_bus_request_name(): Connection ":1.0" is not allowed to own the service "org.freedesktop.Avahi" due to security policies in the configuration file
WARNING: Failed to contact D-Bus daemon.
avahi-daemon 0.6.28 exiting.

Что не так? Это о конфигурации dbus?

Ответы

Ответ 1

У меня была аналогичная проблема, в моем случае по умолчанию avahi-dbus.conf, который поставляется вместе с моей системной пакетной системой, просто не имеет последней "</policy>" до "</busconfig>", которая вызвала эту ошибку.

Сначала я думал, что проблема не исходила из этого файла, так как быстрого просмотра этого недостаточно, чтобы найти такую ​​синтаксическую ошибку.

Ответ 2

Существуют ограничения на то, какой клиент может зарегистрировать какое имя на системной шине. В противном случае пользовательский процесс может получить запрос, предназначенный для некоторой системной службы. Ограничения настраиваются через файл конфигурации dbus-daemon, обычно /etc/dbus-1/system.conf. В стандартных установках этот файл содержит другие файлы конфигурации, особенно все в каталоге /etc/dbus-1/system.d/, где хранятся конфигурации, специфичные для службы. Таким образом, DBus обычно настроен для Avahi:

Пример из моей рабочей станции:

$ cat /etc/dbus-1/system.d/avahi-dbus.conf 
<!DOCTYPE busconfig PUBLIC
          "-//freedesktop//DTD D-BUS Bus Configuration 1.0//EN"
          "http://www.freedesktop.org/standards/dbus/1.0/busconfig.dtd">
<busconfig>

  <!-- Only root or user avahi can own the Avahi service -->
  <policy user="avahi">
    <allow own="org.freedesktop.Avahi"/>
  </policy>
  <policy user="root">
    <allow own="org.freedesktop.Avahi"/>
  </policy>

  <!-- Allow anyone to invoke methods on Avahi server, except SetHostName -->
  <policy context="default">
    <allow send_destination="org.freedesktop.Avahi"/>
    <allow receive_sender="org.freedesktop.Avahi"/>

    <deny send_destination="org.freedesktop.Avahi"
          send_interface="org.freedesktop.Avahi.Server" send_member="SetHostName"/>
  </policy>

  <!-- Allow everything, including access to SetHostName to users of the group "adm" -->
  <policy group="adm">
    <allow send_destination="org.freedesktop.Avahi"/>
    <allow receive_sender="org.freedesktop.Avahi"/>
  </policy>
  <policy user="root">
    <allow send_destination="org.freedesktop.Avahi"/>
    <allow receive_sender="org.freedesktop.Avahi"/>
  </policy>
</busconfig>

Убедитесь, что у вас есть эти стандартные файлы конфигурации или правильная настройка.

Ответ 3

В моем случае мне просто пришлось перезапустить службу dbus.

Вероятно, это связано с тем, что avahi вставил конфигурационный файл dbus (/etc/dbus-1/system.d/avahi-dbus.conf), который не был обнаружен автоматически.