Почему служба dbus работает неправильно?

Я изучал это, это, это и это и не мог найти ответ. Я пытаюсь реализовать Пример 5 из systemd.service, но он не работает. Конечно, причина в том, что я не совсем понял, как работает активация dbus. На мой взгляд, как только имя DBus начинает использоваться, служба активируется, и моя программа запускается. Я слишком далеко?

Итак, чтобы проверить, я хотел, чтобы при запуске моей программы на python3, которая "использует" имя dbus, мой сервис запускался.

В любом случае, кто-нибудь может направить меня в нужное место? Мои файлы:

# cat /etc/systemd/system/mydbus.service
[Unit]
Description=Service Started by DBus name

[Service]
Type=dbus
BusName=org.mybus.demo.test
ExecStart=/bin/echo started
# ExecStart=/usr/bin/dbus-launch /usr/bin/python3 /home/myuser/Documents/dbus/client04.py
# the idea is that my python client up here will run once the server starts "consuming" the dbus name

[Install]
WantedBy=multi-user.target

Ниже мой сервис dbus (я думаю):

# cat /usr/share/dbus-1/system-services/org.mybus.demo.test.service 
[D-BUS Service]
Name=org.mybus.demo.test
Exec=/bin/echo started >> /home/myuser/Documents/dbus/org.mybus.demo.test
User=root
SystemdService=mydbus.service

Теперь я бегу $ sudo journalctl -exfu mydbus, На другом терминале запускаю свой server04.py:

# cat /home/myuser/Documents/dbus/server04.py 
# Importing
from pydbus import SessionBus
from gi.repository import GLib
import time

# Variables / Constants / Instantiation...
bus = SessionBus()
BUS = "org.mybus.demo.test"
loop = GLib.MainLoop()
message_count = 0

class DBusService_XML():
    """
    DBus Service XML Definition.
    type = "i" for integer, "s" for string, "d" for double, "as" list of string data.
    """
    dbus = """
    <node>
        <interface name="{}">
            <method name='greeting'>
                <arg type="s" name="input" direction="in">
                </arg>
                <arg type="s" name="output" direction="out">
                </arg>
            </method>
        </interface>
    </node>
    """.format(BUS)

    def greeting(self, clientName):
        "Receive and send arg"
        print("{} is asking for name".format(clientName))
        return "Hello {}, Im Kyle".format(clientName)

if __name__ == "__main__":
    bus.publish(BUS, DBusService_XML())
    loop.run()

Я думаю, что, делая это, мой mydbus.service начался бы, и я увидел бы "началось" в journalctl, но ничего не произошло. Итак, как мне это сделать?

PS: конечно, когда я запускаю свои server04.py и client04.py вручную с python, все работает.

0 ответов

Другие вопросы по тегам