Почему автозапуск с systemd не работает? - PullRequest
0 голосов
/ 30 апреля 2020

Версия Yocto - воин. Я сделал проект yocto с пользовательским приложением GO / golang (https-сервер), которое прекрасно работает на raspi3. Теперь я пытаюсь запустить его автоматически на изображении yocto, но это не работает. Я знаю, что есть много других вопросов по этому поводу, но я не нашел то, что помогло. Например, я попытался выполнить все шаги в этом посте Включить системные службы, используя yocto , но он не запускается автоматически при распи.

Эти файлы при распи для службы, которую я нашел:

/lib/systemd/system/https-server.service 
/etc/systemd/system/multi-user.target.wants/https-server.service

Само приложение отлично работает, если я запускаю его вручную, оно находится по адресу raspi в / usr / bin / https-server

my build / conf / local.conf:

IMAGE_INSTALL_append = " kernel-image kernel-devicetree sudo apt dnsmasq nano dhcpcd git glibc-utils localedef curl go https-server"
meta-https-server/
├── conf
│   └── layer.conf
└── recipes-https-server
    └── https-server
        ├── files
        │   ├── https-server.go
        │   ├── https-server.service
        │   ├── mytest
        │   ├── server.crt
        │   ├── server.key
        │   └── testvideo.mp4
        ├── go-sw.inc
        └── https-server.bb

https-server.bb

require go-sw.inc

inherit go systemd
#inherit go update-rc.d systemd


SRC_URI += "file://https-server.service"
SRC_URI += "file://https-server.go"

SYSTEMD_PACKAGES = "${PN}"
INITSCRIPT_PACKAGES = "${PN}"
SYSTEMD_SERVICE_${PN} = "https-server.service"

# Path
MY_KEY = "/data/yocto/2020-04-21-poky-warrior/poky-warrior/meta-https-server/recipes-https-server/https-server/files/server.key"
MY_CERT = "/data/yocto/2020-04-21-poky-warrior/poky-warrior/meta-https-server/recipes-https-server/https-server/files/server.crt"
TESTVIDEO = "/data/yocto/2020-04-21-poky-warrior/poky-warrior/meta-https-server/recipes-https-server/https-server/files/testvideo.mp4"
MY_TEST = "/data/yocto/2020-04-21-poky-warrior/poky-warrior/meta-https-server/recipes-https-server/https-server/files/mytest"

# COMPILER
do_compile() {
go build /data/yocto/2020-04-21-poky-warrior/poky-warrior/meta-https-server/recipes-https-server/https-server/files/https-server.go
}


# INSTALL
do_install() {
#   install -d to create directories, "${D}/${bindir}" is /usr/bin

#   systemd
    install -d ${D}${systemd_unitdir}/system
    install -m 0644 ${WORKDIR}/https-server.service ${D}${systemd_unitdir}/system

#   HTTPS certificate and key
    install -d "${D}/${bindir}"
    install -m 0755 "${MY_KEY}"    "${D}/${bindir}"
    install -m 0755 "${MY_CERT}"   "${D}/${bindir}"
    install -m 0777 "${TESTVIDEO}" "${D}/${bindir}"
    install -m 0777 "${MY_TEST}"   "${D}/${bindir}"

#   HTTPS Server Software
    install -m 0755 "${S}/build/https-server" "${D}/${bindir}"

}

FILES_${PN} += "${bindir}"
FILES_${PN} += "${libexecdir}"
FILES_${PN} += "${systemd_system_unitdir}"


REQUIRED_DISTRO_FEATURES= "systemd"

служба https-server.service

[Unit]
Description=HTTPS Server sw startup script

[Service]
ExecStart=/usr/bin/https-server

[Install]
WantedBy=multi-user.target

1 Ответ

0 голосов
/ 04 мая 2020

Я выяснил причину проблемы:

В моей локальной конфигурации в build / conf / local.conf у меня было только это:

    DISTRO_FEATURES_append = " systemd "

после того, как я добавил следующее:

    DISTRO_FEATURES_BACKFILL_CONSIDERED = "sysvinit"
    VIRTUAL-RUNTIME_init_manager = "systemd"
    VIRTUAL-RUNTIME_initscripts = ""

Работало нормально. Процесс https-сервер запущен при запуске. Я проверил запущенные процессы после запуска с помощью ps, так как systemctl не работал на моем образе ядра с минимальным образом:

    root@raspberrypi3:~# ps
    [...]
    152 root      861m S    /usr/bin/https-server
    [...]
    root@raspberrypi3:~#

Так что это имело значение. Не знаю, был ли неправильный пробел в моем DISTRO_FEATURES_append = "systemd" также неправильно ... ??

    #DISTRO_FEATURES_append = " systemd"

    DISTRO_FEATURES_append = " systemd "
    DISTRO_FEATURES_BACKFILL_CONSIDERED = "sysvinit"
    VIRTUAL-RUNTIME_init_manager = "systemd"
    VIRTUAL-RUNTIME_initscripts = ""

oe-pkgdata-util, который предложил @Nayfe, очень полезный инструмент здесь:

user@machine:[...]/poky-warrior/build$ 
oe-pkgdata-util list-pkg-files -p https-server
https-server:
        /lib/systemd/system/https-server.service
        /usr/bin/https-server
        /usr/bin/mytest
        /usr/bin/server.crt
        /usr/bin/server.key
        /usr/bin/testvideo.mp4
https-server-dbg:
        /usr/bin/.debug/https-server
https-server-dev:
https-server-ptest:

Я также работал над рецептом https-server.bb сверху, чтобы избежать абсолютных путей, как предложил @Nayfe. Это не вызывало проблемы, но это был плохой стиль.

Не используйте / data / yocto / 2020-04-21-poky-warrior / poky-warrior / meta-https-server / recipes-https-server / https-server / files / prefix и добавьте все файлы в SRC_URI вместо этого.

require go-sw.inc

inherit go systemd

#  "${D}/${bindir}" is /usr/bin 
#  ${WORKDIR} is path at local directory, 
#  this can be used instead of absolute paths

SRC_URI += "file://https-server.service"
SRC_URI += "file://https-server.go"
SRC_URI += "file://server.key"
SRC_URI += "file://server.crt"
SRC_URI += "file://testvideo.mp4"
SRC_URI += "file://mytest"

SYSTEMD_PACKAGES = "${PN}"
INITSCRIPT_PACKAGES = "${PN}"
SYSTEMD_SERVICE_${PN} = "https-server.service"

# COMPILER
do_compile() {
go build ${WORKDIR}/https-server.go
}


# INSTALL
do_install() {
#   install -d to create directories, "${D}/${bindir}" is /usr/bin

#   systemd
    install -d ${D}${systemd_unitdir}/system
    install -m 0644 ${WORKDIR}/https-server.service ${D}${systemd_unitdir}/system

#   HTTPS certificate, key and testdata for https-server
    install -d "${D}/${bindir}"
    install -m 0755  ${WORKDIR}/server.key     "${D}/${bindir}"
    install -m 0755  ${WORKDIR}/server.crt     "${D}/${bindir}"
    install -m 0777  ${WORKDIR}/testvideo.mp4  "${D}/${bindir}"
    install -m 0777  ${WORKDIR}/mytest         "${D}/${bindir}"

#   HTTPS Server Software
    install -m 0755 "${WORKDIR}/build/https-server" "${D}/${bindir}"
}

# FILES_${PN} is Yocto’s way of specifying
# which files are expected to be installed along with which package
# (${PN} is a variable holding the main package’s name).
FILES_${PN} += "${bindir}"
FILES_${PN} += "${libexecdir}"
FILES_${PN} += "${systemd_system_unitdir}"

REQUIRED_DISTRO_FEATURES= "systemd"

Спасибо @kostix и @nayfe за их предложения.

...