다시 시작할 때 systemd 서비스가 tmux 명령을 트리거하지 않습니다.

다시 시작할 때 systemd 서비스가 tmux 명령을 트리거하지 않습니다.

linux-mainline커널 기반 Yocto 이미지를 사용하고 있습니다 . systemd내가 만든 임베디드 운영 체제가 있습니다 .

목적

usb_modeswitch동글을 식별하고 wvdial3G 인프라에 연결하는 데 사용되는 마더보드에 UMTS 동글이 연결되어 있습니다 .

방법

/usr/umts.sh다음과 같이 간단한 bash 스크립트를 작성했습니다.

#!/bin/bash

sleep 1;
usb_modeswitch --default-vendor 12d1 --default-product 1446 -J

sleep 1;
/usr/bin/tmux new-session -d -s Cloud
/usr/bin/tmux set-option set-remain-on-exit on
/usr/bin/tmux new-window -d -n 'wvdial' -t Cloud:1 'sleep 1; /usr/bin/wvdialconf; /usr/bin/wvdial';

usb_modeswitchtmuxUSB 동글이 구성되고 세션과 트리거가 다음 섹션에서 생성됩니다 wvdial.

systemd스크립트는 다음과 같습니다/etc/systemd/system/enable-umts.service

GNU nano 2.2.5 파일: /etc/systemd/system/enable-umts.service

[Unit]
Description=Enable UMTS Dongle for Cloud Connectivity

[Service]
Type=oneshot
ExecStart=/usr/umts.sh

[Install]
WantedBy=default.target

(저는 Grant Script Execution Rights를 사용했습니다 chmod +x /usr/umts.sh)

데몬을 다시 로드 systemctl daemon-reload하고 서비스를 활성화했습니다.systemctl enable enable-umts.service

마더보드를 다시 시작합니다(참고: root마더보드만 있고 다른 것은 없습니다 user).

실제로 위의 스크립트 dmesg트리거에서 관련 메시지가 표시됩니다.usb_modeswitch

[  OK  ] Started Enable UMTS Dongle for Cloud Connectivity.
[   13.051247] scsi host2: usb-storage 1-1:1.5
[   13.067326] usb-storage 1-1:1.6: USB Mass Storage device detected
[   13.074645] scsi host3: usb-storage 1-1:1.6
[   13.158627] usbcore: registered new interface driver usbserial
[   13.165501] usbcore: registered new interface driver usbserial_generic
[   13.174754] usbserial: USB Serial support registered for generic
[   13.202356] usbcore: registered new interface driver option
[   13.208714] usbserial: USB Serial support registered for GSM modem (1-port)
[   13.216468] option 1-1:1.0: GSM modem (1-port) converter detected
[   13.229840] usb 1-1: GSM modem (1-port) converter now attached to ttyUSB0
[   13.238774] option 1-1:1.3: GSM modem (1-port) converter detected
[   13.248906] usb 1-1: GSM modem (1-port) converter now attached to ttyUSB1
[   13.256172] option 1-1:1.4: GSM modem (1-port) converter detected
[   13.264467] usb 1-1: GSM modem (1-port) converter now attached to ttyUSB2
[   14.069960] scsi 2:0:0:0: CD-ROM            HUAWEI   Mass Storage     2.31 PQ: 0 ANSI: 2
[   14.088684] scsi 3:0:0:0: Direct-Access     HUAWEI   TF CARD Storage       PQ: 0 ANSI: 2
[   14.127686] sd 3:0:0:0: [sda] Attached SCSI removable disk
GSM modem (1-port) converter detected
] usb 1-1: GSM modem (1-port) converter now attached to ttyUSB0
[   13.238774] option 1-1:1.3: GSM modem (1-port) converter detected
[   13.248906] usb 1-1: GSM modem (1-port) converter now attached to ttyUSB1
[   13.256172] option 1-1:1.4: GSM modem (1-port) coPassword

하지만 로그인 후 세션 목록을 확인하려고 하면 tmux ls세션이 생성되지 않은 것으로 표시됩니다.

`스크립트가 실제로 실패하지는 않으며 서비스 상태는 다음과 같습니다.

● enable-umts.service - Enable UMTS Dongle for Cloud Connectivity
   Loaded: loaded (/etc/systemd/system/enable-umts.service; enabled; vendor preset: enabled)
   Active: inactive (dead) since Thu 2018-05-17 12:52:10 UTC; 4min 51s ago
  Process: 214 ExecStart=/usr/umts.sh (code=exited, status=0/SUCCESS)
 Main PID: 214 (code=exited, status=0/SUCCESS)

May 17 12:52:09 phyboard-mira-imx6-3 umts.sh[214]: Set up interface 0
May 17 12:52:09 phyboard-mira-imx6-3 umts.sh[214]: Use endpoint 0x01 for message sending ...
May 17 12:52:09 phyboard-mira-imx6-3 umts.sh[214]: Trying to send message 1 to endpoint 0x01 ...
May 17 12:52:09 phyboard-mira-imx6-3 umts.sh[214]:  OK, message successfully sent
May 17 12:52:09 phyboard-mira-imx6-3 umts.sh[214]: Reset response endpoint 0x81
May 17 12:52:09 phyboard-mira-imx6-3 umts.sh[214]: Reset message endpoint 0x01
May 17 12:52:09 phyboard-mira-imx6-3 umts.sh[214]:  Could not reset endpoint (probably harmless): -99
May 17 12:52:09 phyboard-mira-imx6-3 umts.sh[214]:  Device is gone, skip any further commands
May 17 12:52:09 phyboard-mira-imx6-3 umts.sh[214]: -> Run lsusb to note any changes. Bye!
May 17 12:52:10 phyboard-mira-imx6-3 systemd[1]: Started Enable UMTS Dongle for Cloud Connectivity.

스크립트를 독립 실행형 스크립트로 실행 하면 /usr/umts.sh실제로 수행해야 하는 모든 작업을 수행합니다(새 tmux세션을 열고 트리거 wvdial).

여기에 문제가 있나요? 시간을 더 추가하려고 했지만 sleep역시 효과가 없었습니다. 안타깝게도 제가 작업 중인 yocto 이미지를 사용할 수 없거나 rc.local사용할 수 없습니다.cron

답변1

RemainAfterExit=yes|truesystemd스크립트 에 다음을 추가 했습니다 .

[Unit]
Description=Enable UMTS Dongle for Cloud Connectivity

[Service]
Type=oneshot
ExecStart=/usr/umts.sh
RemainAfterExit=true
[Install]
WantedBy=default.target

umts.sh다음과 같이 스크립트에 전체 경로를 추가했습니다 .

#!/bin/bash

    sleep 1;
    /usr/bin/tmux new-session -d -s Cloud
    /usr/bin/tmux set-option set-remain-on-exit on
    /usr/bin/tmux new-window -d -n 'usb_modeswitch' -t Cloud:2 '/usr/sbin/usb_modeswitch --default-vendor 12d1 --default-product 1446 -J';

    /usr/bin/tmux new-window -d -n 'wvdial' -t Cloud:1 'sleep 10; /usr/bin/wvdialconf; /usr/bin/wvdial';

데몬 다시 로드

systemctl daemon-reload

그리고 마더보드를 다시 시작하세요. tmux세션이 생성되어 완벽하게 실행되었음을 확인했습니다.

관련 정보