Am un script pe care l-am scris care ascultă pe mqtt.
Când un anumit cod ajunge la serverul mqtt, atunci o sesiune ngrok este începută astfel:
subprocess.Popen(['/tmp/ngrok','http' ,'8080'], stdout=subprocess.DEVNULL, stderr=subprocess.DEVNULL)
scruptul rulează într-un virtualenv și acolo are un script shell pentru a activa mediul virtual și a-l rula:
#!/bin/bash
. ./venv/bin/activate
python mqtt_listener.py
Când rulez acest script în shell-ul meu cu & în cele din urmă se deschide sesiunea ngrok și este lăsată deschisă nicl până când o omor eu.
Cu toate acestea, atunci când rulați în systemd folosind următorul fișier de sistem (fișier utilizator)
/home/myuser/.config/systemd/user/mqtt_listener.service
[Unitate]
Descriere=mqtt run service
După=default.target
[Serviciu]
Tip=exec
ExecStart=/home/myuser/mqtt_listener/run_mqtt_service.sh
KillMode=proces
[Instalare]
WantedBy=default.target
odată ce serviciul primește comanda mqtt, pot vedea jurnalele de jurnal, serviciul a primit mesajul meu și a bifurcat procesul ngrok, dar apoi pot vedea
serviciul a fost „dezactivat cu succes” și apoi repornește.
Lucrul ciudat este că se întâmplă întotdeauna când nu sunt conectat folosind ssh la server, dacă sunt autentificat, procesul nu va muri.
Ai idee ce greșesc? tipul=exec se datorează faptului că ceilalți pur și simplu nu s-au potrivit. Nu pot să-mi dau seama de ce systemd consideră că serviciul meu python este finalizat și, astfel, îl oprește după un fork nepot (primul fork este scriptul de rulare, care aparent pot scapa de).