1

在 hacking 的过程中dbus-monitor,我尝试连接到 Avahi 守护进程:

$ dbus-monitor --system \
  "type='signal',interface='org.freedesktop.Avahi.Server',member='StateChanged'"

这将响应 Avahi 守护程序状态的变化。

$ sudo restart avahi-daemon

signal sender=org.freedesktop.DBus -> 
         dest=:1.315 
         serial=2
         path=/org/freedesktop/DBus;
         interface=org.freedesktop.DBus;
         member=NameAcquired
    string ":1.315"

signal sender=:1.318 ->
         dest=(null destination)
         serial=4
         path=/;
         interface=org.freedesktop.Avahi.Server; 
         member=StateChanged
    int32 1
    string "org.freedesktop.Avahi.Success"

signal sender=:1.318 -> 
         dest=(null destination)
         serial=13
         path=/;
         interface=org.freedesktop.Avahi.Server;
         member=StateChanged
    int32 2
    string "org.freedesktop.Avahi.Success"

但是,我无法浏览这样的服务。

$ dbus-send --system --dest=org.freedesktop.Avahi --print-reply \
    / org.freedesktop.Avahi.Server.ServiceBrowserNew \
    int32:-1 int32:-1 string:'_http._tcp' string:'local' uint32:0

method return sender=:1.345 -> 
         dest=:1.354
         reply_serial=2
    object path "/Client5/ServiceBrowser1"

$ dbus-monitor --system \
    "type='signal',interface='org.freedesktop.Avahi.ServiceBrowser'"

据我了解,这应该响应新的/删除的 http 服务实例,但它没有。

为什么?

更新:

使用 python 和 c API 执行上述 shell 命令的等效项按预期工作。但是,他们无法连接到我使用构建的 ServiceBrowserdbus-send并且我无法使用dbus-monitor来收听他们构建的 ServiceBrowser。

在这一点上,我最好的猜测是:

  1. 一旦连接关闭(通过dbus-send命令终止),我创建的 ServiceBrowser 将被销毁。但是,这并不能解释为什么 dbus-monitor无法连接到与我的 python 脚本进行主动通信的 ServiceBrowser。
  2. 来自 ServiceBrowser 的信号仅发送到实例化它们的连接。
4

0 回答 0