在 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。
在这一点上,我最好的猜测是:
- 一旦连接关闭(通过
dbus-send
命令终止),我创建的 ServiceBrowser 将被销毁。但是,这并不能解释为什么dbus-monitor
无法连接到与我的 python 脚本进行主动通信的 ServiceBrowser。 - 来自 ServiceBrowser 的信号仅发送到实例化它们的连接。