起動時にユーザーのPythonアプリケーションサービスが起動しない

起動時にユーザーのPythonアプリケーションサービスが起動しない

私のユーザーサービスはPythonスクリプトで、起動時には実行されません。 Raspbianオペレーティングシステムでユーザーpiとして実行されます。ほとんどの問題と同様に、サービスを開始でき、正常に実行されますが、再systemctl --user start argus起動時には起動しません。

[Unit]
Description=RAL Argus Service

[Service]
Environment=PYTHONUNBUFFERED=1
ExecStart=/usr/bin/python3 /home/pi/RAL/Argus/Hextapus_Base.py -bsi=5 -pupd=59 -bm=1
RemainAfterExit=yes
Restart=no

[Install]
WantedBy=multi-user.target

sudo loginctl --linger $USERpiユーザーがログインしていなくてもサービスが実行されるように実行されています。

スクリプトは、実行中にセンサーからデータを収集し、データ収集が完了するとデバイスをシャットダウンします(即時sudo shutdown実行)。 RTCはシステムを再起動し、スクリプトが実行され、プロセスが再び繰り返されます。

起動時の出力は次のとおりです。systemctl --user status argus

pi@raspberrypi:~ $ systemctl --user status argus
â—� argus.service - RAL Argus Service
   Loaded: loaded (/home/pi/.config/systemd/user/argus.service; enabled; vendor preset: enabled)
   Active: inactive (dead)

これは台本の核心です。


def main():
    args=cli(argv) #parse args

    try:
        
        normal_operation(args)
            
        rtc_time = Hextapus.Get_string_utc_time_pcf(0)
        logger.warning("Issuing Shutdown command at RTC Time: {}".format(rtc_time))    #Indicate os shutdown during hard shutdown and RTC time stamp      
        os.system('sudo shutdown now')    
        return 0
        
    except KeyboardInterrupt:
        #This is so when debugging the loops are killed quickly
        logger.warning("Keyboard ESCAPE detected. Shutting Down")
            

if __name__ == '__main__':
       
    sys.exit(main(sys.argv))

systemctl --user start argusを実行すると、サービスの問題がpiで終了するため、Journalctlに次のように表示されます。

Dec 03 20:35:39 raspberrypi python3[27653]: 2020-12-03 20:35:39,502 - WARNING - Issuing Shutdown command at RTC Time: 20201203203543
Dec 03 20:35:43 raspberrypi systemd[385]: Stopping RAL Argus Service...
Dec 03 20:35:43 raspberrypi systemd[385]: argus.service: Main process exited, code=killed, status=15/TERM
Dec 03 20:35:43 raspberrypi systemd[385]: argus.service: Succeeded.
Dec 03 20:35:43 raspberrypi systemd[385]: Stopped RAL Argus Service.

後で開始すると、サービスが実行中または開始できないことを示す追加情報がジャーナルctlにありません。スクリプトが閉じているという事実が私の問題の原因であるかどうかはわかりません。

ありがとうございます!

ベストアンサー1

systemdのユーザーインスタンスでサービスを実行したい場合は、default.targetnotを使用する必要がありますmulti-user.targetmulti-user.targetsystemdのユーザーインスタンスでは使用されません。

バラよりhttps://www.freedesktop.org/software/systemd/man/systemd.special.html#default.target1

おすすめ記事