python:简单的dbus example- os.fork()在服务例程中?

时间:2012-05-30 04:19:29

标签: python dbus

我正在尝试编写dbus服务器,我想在这里运行一些外部shell程序(grep)来完成这项工作。

当我这样做时:

提示$ server.py

然后:

提示$ client.py#工作正常,即。在子进程中运行grep命令。

提示$ client.py#...,但第二次调用会产生以下错误消息:

DBusException:org.freedesktop.DBus.Error.ServiceUnknown:任何.service文件都没有提供名称org.example.ExampleService

我被困住了。你能帮助我吗?

这里是server.py(之后是client.py):

import gtk, glib
import os
import dbus
import dbus.service
import dbus.mainloop.glib
import subprocess

messages_queue=list()
grep_pid=0


def queue_msg(message):
    global messages_queue
    messages_queue.append(message)
    return

def dequeue_msg():
    global messages_queue,grep_pid
    if grep_pid != 0:
        try:
            pid=os.waitpid(grep_pid,os.P_NOWAIT)
        except:
            return True
        if pid[0] == 0:
            return True
        grep_pid=0

    if len(messages_queue) == 0:
            return True
    else:
            tekst=messages_queue.pop(0)

        cmd="grep 'pp'"

        print cmd
        #works fine, when I do return here
        #return True

    grep_pid=os.fork()
    if grep_pid != 0:
        return True
    os.setpgid(0,0)
    pop=subprocess.Popen(cmd,shell=True,stdin=subprocess.PIPE)
    pop.stdin.write(tekst)
    pop.stdin.close()
    pop.wait()
    exit(0)

class DemoException(dbus.DBusException):
    _dbus_error_name = 'org.example.Exception'

class MyServer(dbus.service.Object):

    @dbus.service.method("org.example.ExampleInterface",
                         in_signature='', out_signature='')
    def QueueMsg(self):
            queue_msg("ppppp")

    @dbus.service.method("org.example.ExampleInterface",
                         in_signature='', out_signature='')
    def Exit(self):
        mainloop.quit()

from dbus.mainloop.glib import threads_init

if __name__ == '__main__':
        glib.threads_init()

        threads_init()

        dbus.mainloop.glib.DBusGMainLoop(set_as_default=True)

        session_bus = dbus.SessionBus()
        name = dbus.service.BusName("org.example.ExampleService", session_bus)
        object = MyServer(session_bus, '/My')

        glib.timeout_add_seconds(1, dequeue_msg)
        mainloop = glib.MainLoop()
        print "Running example service."
        mainloop.run()

现在client.py:

import sys
from traceback import print_exc
import dbus

def main():
    bus = dbus.SessionBus()

    try:
        remote_object = bus.get_object("org.example.ExampleService",
                                       "/My")

    except dbus.DBusException:
        print_exc()
        sys.exit(1)

    iface = dbus.Interface(remote_object, "org.example.ExampleInterface")

    iface.QueueMsg()

    if sys.argv[1:] == ['--exit-service']:
        iface.Exit()

if __name__ == '__main__':
    main()

2 个答案:

答案 0 :(得分:0)

当您尝试访问不再可用的服务时,通常会收到此错误消息。检查您的服务器是否仍在运行。

您可以使用d-feet调试dbus连接。

答案 1 :(得分:0)

有关缺少的.service文件的错误消息意味着您需要在dbus-1 / services中创建服务文件。

例如:

# /usr/local/share/dbus-1/services/org.example.ExampleService.service
[D-BUS Service]
Name=org.example.ExampleService
Exec=/home/user1401567/service.py

许多教程都不包含这些细节(也许.service文件不是必需的?)但是,至少在Ubuntu 12.04上,没有它就无法连接dbus服务。