systemd는 장치가 제거될 때 서비스를 중지하지 않습니다.

systemd는 장치가 제거될 때 서비스를 중지하지 않습니다.

udev 규칙이 있습니다.

ACTION=="add", SUBSYSTEM=="usb", ATTR{idVendor}=="1a86", ATTR{idProduct}=="7523", TAG+="systemd", ENV{SYSTEMD_WANTS}+="klipper.service"

원래 서비스는 sysv 파일입니다.

pi@octopi:/etc/udev/rules.d $ sudo service klipper status
● klipper.service - Modiffied Klipper systemd file
   Loaded: loaded (/etc/init.d/klipper; generated; vendor preset: enabled)
  Drop-In: /etc/systemd/system/klipper.service.d
           └─override.conf

따라서 다음을 사용하여 덮어쓴 sudo systemctl edit klipper.service다음 재정의 파일에 다음을 입력합니다.

[Unit]
Description=Modiffied Klipper systemd file
StopWhenUnneeded=yes

이제 장치를 분리해도 서비스는 "활성" 상태로 유지되고 중지되지 않습니다.

그들은 이렇게 하는 것을 권장합니다: https://bugzilla.redhat.com/show_bug.cgi?id=871074

장치가 제거되면 서비스가 중지되기를 원합니다.

이것은 sysv init 파일의 내용입니다.

#!/bin/sh
# System startup script for Klipper 3d-printer host code

### BEGIN INIT INFO
# Provides:          klipper
# Required-Start:    $local_fs
# Required-Stop:
# Default-Start:     2 3 4 5
# Default-Stop:      0 1 6
# Short-Description: Klipper daemon
# Description:       Starts the Klipper daemon.
### END INIT INFO

PATH=/usr/local/sbin:/usr/local/bin:/usr/sbin:/usr/bin:/sbin:/bin
DESC="klipper daemon"
NAME="klipper"
DEFAULTS_FILE=/etc/default/klipper
PIDFILE=/var/run/klipper.pid

. /lib/lsb/init-functions

# Read defaults file
[ -r $DEFAULTS_FILE ] && . $DEFAULTS_FILE

case "$1" in
start)  log_daemon_msg "Starting klipper" $NAME
        start-stop-daemon --start --quiet --exec $KLIPPY_EXEC \
                          --background --pidfile $PIDFILE --make-pidfile \
                          --chuid $KLIPPY_USER --user $KLIPPY_USER \
                          -- $KLIPPY_ARGS
        log_end_msg $?
        ;;
stop)   log_daemon_msg "Stopping klipper" $NAME
        killproc -p $PIDFILE $KLIPPY_EXEC
        RETVAL=$?
        [ $RETVAL -eq 0 ] && [ -e "$PIDFILE" ] && rm -f $PIDFILE
        log_end_msg $RETVAL
        ;;
restart) log_daemon_msg "Restarting klipper" $NAME
        $0 stop
        $0 start
        ;;
reload|force-reload)
        log_daemon_msg "Reloading configuration not supported" $NAME
        log_end_msg 1
        ;;
status)
        status_of_proc -p $PIDFILE $KLIPPY_EXEC $NAME && exit 0 || exit $?
        ;;
*)      log_action_msg "Usage: /etc/init.d/klipper {start|stop|status|restart|reload|force-reload}"
        exit 2
        ;;
esac
exit 0

답변1

StopWhenUnneeded=true 하다필요에 따라 작업하십시오. 작동하지 않는 것은 장치를 비활성화하는 것입니다.

systemctl status DEVICENAME.device장치를 삽입하고 제거하여 이를 확인할 수 있습니다 . 전원을 연결하면 장치가 활성화된다는 것을 알 수 있을 것입니다.활동적으로 지내다삭제 후.

그것을 찾으려면 를 DEVICENAME살펴보세요 systemctl list-units --type=device. udev 규칙에 추가하여 ENV{SYSTEMD_ALIAS}="..."장치에 더 예측 가능한 단위 이름을 제공할 수도 있습니다. 바라보다 man systemd.device.

이 문제에 대한 자세한 문서는 다음 사이트에 있습니다.https://github.com/systemd/systemd/issues/7587. 문제는 장치 제거를 위한 커널 이벤트에 레이블이 누락되어 있으며 장치 장치를 비활성화하는 방법을 알 수 있도록 시스템으로 라우팅할 수도 없다는 것입니다.

해결책systemd태그를 추가하는 udev 규칙을 추가하기만 하면 됩니다 . 귀하의 경우에는 다음과 같을 수 있습니다.

ACTION=="remove", SUBSYSTEM=="usb", ENV{PRODUCT}=="1a86/7523/*", TAG+="systemd"

완료되면 장치 단위가 장치의 현재 연결/분리 상태를 반영하는지 확인할 수 있어야 하며 StopWhenUnneeded=true서비스 단위에서는 장치가 연결 해제될 때 서비스가 중지됩니다.

답변2

이것이 버그질라 항목에 제안되어 있지만 이것이 StopWhenUnneeded=true장치 제거에 영향을 미칠지는 확실하지 않습니다. man systemd.unit이 키워드의 경우 다음과 같습니다.

기본적으로 systemd는 다른 유닛과 충돌하거나 사용자가 명시적으로 종료를 요청하지 않는 한 유닛을 중지하지 않습니다.

Bugzilla를 만든 사람은 두 번째 udev 규칙을 만들었는데, 여러분에게는 다음과 같이 보일 것입니다.

ACTION=="remove", SUBSYSTEM=="usb", ATTR{idVendor}=="1a86", ATTR{idProduct}=="7523", RUN+="/bin/systemctl --no-block stop klipper.service"

관련 정보