Portál AbcLinuxu, 5. května 2025 15:20

Dotaz: Jak spustit proces když systemd spustí konkrétní proces

23.7.2020 23:56 LarryL | skóre: 27
Jak spustit proces když systemd spustí konkrétní proces
Přečteno: 971×
Odpovědět | Admin
Ahoj, potřeboval bych poradit se systemd.

Mám spuštěnou službu bumblebeed:
systemctl status bumblebeed
● bumblebeed.service - Bumblebee C Daemon
     Loaded: loaded (/usr/lib/systemd/system/bumblebeed.service; enabled; vendor preset: disabled)
     Active: active (running) since Wed 2020-07-22 10:33:32 CEST; 1 day 13h ago
   Main PID: 656 (bumblebeed)
      Tasks: 1 (limit: 18816)
     Memory: 17.2M
     CGroup: /system.slice/bumblebeed.service
             └─656 /usr/bin/bumblebeed --use-syslog
Ta služba si spouští další proces "Xorg :8 -config...", takže výpis pak vypadá takto:
systemctl status bumblebeed
● bumblebeed.service - Bumblebee C Daemon
     Loaded: loaded (/usr/lib/systemd/system/bumblebeed.service; enabled; vendor preset: disabled)
     Active: active (running) since Wed 2020-07-22 10:33:32 CEST; 1 day 11h ago
   Main PID: 656 (bumblebeed)
      Tasks: 2 (limit: 18816)
     Memory: 30.6M
     CGroup: /system.slice/bumblebeed.service
             ├─  656 /usr/bin/bumblebeed --use-syslog
             └─52090 /usr/lib/Xorg :8 -config ...
Já bych potřeboval spustit svůj bash script ve chvíli kdy si služba bumblebeed spustí proces "Xorg :8 -config...". Existuje nějaká taková možnost v systemd? Vím, že existuje "Before", "After", ale to v tomto případě asi nepomůže.

Řešení dotazu:


Nástroje: Začni sledovat (0) ?Zašle upozornění na váš email při vložení nového komentáře.

Odpovědi

Jendа avatar 24.7.2020 00:54 Jendа | skóre: 78 | blog: Jenda | JO70FB
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Odpovědět | | Sbalit | Link | Blokovat | Admin
Ten fork+exec už provede bumblebeed? Pak to podle mě nemá systemd jak odchytit (kromě teda toho, že by dělal strace na fork). <fuj>Nahradit /usr/lib/Xorg za wrapper shell skript</fuj>
24.7.2020 12:10 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Hmm, udělat wraper na celý Xorg by asi bylo fuj. Proces "Xorg :8" se spouští když použiji příkaz:

DISPLAY=:8 optirun <jméno_aplikace> # optirun je součást bumblebee

Takže pokud v systemd neexistuje žádná možnost, tak bych používal něco jako:

DISPLAY=:8 muj_optirun.sh <jméno_aplikace>
24.7.2020 08:12 Filip Jirsák | skóre: 68 | blog: Fa & Bi
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Odpovědět | | Sbalit | Link | Blokovat | Admin
V tomhle vám systemd nepomůže, o tom spuštění dceřiného procesu se nedozví. Ten hlavní proces bumblebeed (nastartovaný systemd) zůstává pořád běžet? Systemd umožňuje reagovat na to, že služba už je nastartovaná, ale musí se o tom dozvědět. Možností je několik – služba pošle signál přes D-Bus, zavolá API systemd, a jedna z možností určená pro legacy aplikace je ta, že se ten proces, který byl spuštěn systemd, ukončí (protože mezi tím odforkoval jiné procesy).
24.7.2020 09:22 Vantomas | skóre: 32 | Praha
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Na tohle by šel možná navěsit nějaký skript, co sleduje existenci Xorg procesu + nějaký sleep a pak použít AfterStart.
24.7.2020 12:12 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Ten hlavní proces bumblebeed (nastartovaný systemd) zůstává pořád běžet?
Ano, zůstává pořád běžet. Výpis služby vypadá takto:
systemctl cat bumblebeed
# /usr/lib/systemd/system/bumblebeed.service
[Unit]
Description=Bumblebee C Daemon

[Service]
Type=simple
ExecStart=/usr/bin/bumblebeed --use-syslog
Restart=always
RestartSec=60

[Install]
WantedBy=multi-user.target
24.7.2020 09:52 z_sk | skóre: 34 | blog: analyzy
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Odpovědět | | Sbalit | Link | Blokovat | Admin
Na co to je dobre prakticky?
debian.plus@protonmail.com
24.7.2020 11:40 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Je to dobré na to co jsem řešil v jiném vlákně - Přepínání klávesnice a myši mezi dvěma procesy Xorg. Hlavní nevýhoda použití xinput je, že při startu nové instance "Xorg :8 ...", funguje klávesnice i myš na "Xorg :0" i "Xorg :8" současně. Potřebuji tudíž ihned po spuštění nové instance Xorg :8 spustit můj script, který na něm vypne klávesnci a myš. Pokud bych měl monitor připojený k Xorg :8 vyplý a neuvědomil si, že mi tam běží nějaká aplikace nebo nějaký DE, tak bych si celou aplikaci nebo DE rozhodil. V horším případě i nechtěně smazal soubory.

Mohl bych udělat samostatný script na 3 řádky v bashi, který bude na pozadí každé 3 sekundy kontrolovat zda není spuštěna jiná instance Xorg, ale zdá se mi to špinavé řešení. Kdyby to pomocí závislostí hlídal přímo systemd, tak by to bylo lepší.
24.7.2020 14:30 Filip Jirsák | skóre: 68 | blog: Fa & Bi
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Potřebuji tudíž ihned po spuštění nové instance Xorg :8 spustit můj script, který na něm vypne klávesnci a myš.
To vypadá jako rovnák na ohejbák. Nešlo by zařídit, aby se tam ta klávesnice a myš vůbec nepřipojila?
24.7.2020 15:46 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
To by šlo zařídit. Ve výchozím stavu existuje soubor /etc/bumblebee/xorg.conf.d/10-ignore-devices.conf, který obsahuje toto:
# If you connect a display to one of the outputs wired to the Nvidia card, you
# have to comment this whole file. Note that you can leave it commented even
# without currently attached monitor, at the cost of greater optirun startup
# time.

Section "InputClass"
    Identifier  "IgnoreDevices"
    MatchDevicePath "/dev/input/event*|/dev/input/mouse*|/dev/input/js*|/dev/input/mice*"
    Option      "Ignore" "true"
EndSection
Jenomže, pak nefunguje klávesnice a myš na "Xorg :8" vůbec a nevím o tom, že by šla nějak zapnout bez resetu Xka. Já potřebuji přehazovat jednu klávesnici a jednu myš mezi oběma Xkama. Script na přepínání už mám hotový (řešil jsem v tom vedlejším vlákně). Jedině, že by existoval nějaký parametr při spuštění Xorg, něco jako "/usr/lib/Xorg :8 -disable input ...", ale jak jsem googlil, tak jsem nic takového nenašel. Všichni vypínají klávesnice, myši a touchpady pomocí xinput. Takže z toho mně vyplývá, že jediná varianta je:

- nejdřív musím zapnout "Xorg :8",

- potom pomocí xinput vypnout klávesnici a myš.
24.7.2020 16:26 z_sk | skóre: 34 | blog: analyzy
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Maj defaulne vypnutu a zapinaj kde treba. a osetruj v xinit.rc ci ako sa to vola, co sa vola pri starte (pred alebo po) x servera.

vypnutie default: https://unix.stackexchange.com/questions/63404/how-can-i-automatically-disable-my-laptops-built-in-keyboard-in-x-org
debian.plus@protonmail.com
24.7.2020 17:38 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
To co je v tom odkazu, tak vypne klávesnici a myš při startu Xka, ale už nejdou nijak zapnout. Nebo se pletu?

Pomocí Xinit by to možná šlo.
24.7.2020 19:14 z_sk | skóre: 34 | blog: analyzy
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Skus, zistis. Ja to az tak nepotrebujem vediet ;)
debian.plus@protonmail.com
24.7.2020 21:03 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Já jsem to zjistil už v tom vlákně kde jsi mi i ty radil použít "xinit --disable/--enable". Taky jsem to uvedl o dva komenty výše kde jsem vložil obsah souboru "10-ignore-devices.conf" což je to samé co ve tvém odkazu. Takže proto se divím proč mi to radíš :-) Myslel jsem, že jsem se spletl a ty znáš nějaké řešení.

Jde o to, že když vytvoříš ten conf soubor co je i v tom tvém odkazu, tak tím řekneš Xku, aby vůbec nenačetl vstupní zařízení. Takže výpis ukazuje toto:
DISPLAY=:8 xinput --list
⎡ Virtual core pointer                    	id=2	[master pointer  (3)]
⎜   ↳ Virtual core XTEST pointer              	id=4	[slave  pointer  (2)]
⎣ Virtual core keyboard                   	id=3	[master keyboard (2)]
    ↳ Virtual core XTEST keyboard             	id=5	[slave  keyboard (3)]
Tudíž tam není načtena žádná klávesnice ani myš a proto nemohu příkazem xinput --enable žádné zařízení zapnout.
26.7.2020 21:06 samalama
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
ot: toho debiliana- si nevsimaj, on necita vobec diskusie, len kopiruje otazky do gugel translatora, potom do gugla a potom len hadze linky do fora ako "odpoved"...
26.7.2020 21:53 z_sk | skóre: 34 | blog: analyzy
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Nie vzdy.
debian.plus@protonmail.com
28.7.2020 12:20 KarelK
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Něco mi uniká? Proč prostě nevypneš myš a klávesnici přes xinput pří startu "Xorg :8" buď klasicky přes .xinitrc nebo přes session managera DE?
28.7.2020 13:12 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
.xinitrc nefunguje protože se nepoužívá startx ale přímo příkaz "/usr/lib/Xorg :8 ..." - viz níže v diskuzi.

DE na "Xorg :8" nespouštím. Spouštím tam jen windows managera (xfwm4) a daný program si spustím z "Xorg :0". Jako trochu jsem uvažoval, že na :8 spustím DE, ale:

za a) to teď nepotřebuji

za b) XFCE mi běží na "Xorg :0" a nejsem si jistý jestli je správné (bezpečné) spouštět XFCE ve druhé instanci na "Xorg :8" pod stejným uživatelem. Znamenalo by to, že obě instance budou používat stejné konfiguráky a nerad bych si XFCE rozhodil. Mohl bych použít jiný DE, ale zase mít 2 různé prostředí mně nepřijde moc přívětivé.
28.7.2020 15:31 GeorgeWH | skóre: 42
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
a ~/.Xsession?
28.7.2020 16:34 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Taky ne. Zkoušel jsem i ~/.xsession

Myslím, že se všechny tyto soubory spouští jen při použití startx nebo xinit nebo si je spouští display manager. Samotný proces /usr/lib/Xorg je nenačítá.
28.7.2020 21:13 GeorgeWH | skóre: 42
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
No hej, ~/.Xsession sa spusti po prihlaseni sa.
24.7.2020 15:17 PetebLazar | skóre: 34 | blog: l_eonardovo_odhodlani
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Nešlo by přiřadit každému z Xorgů vlastní KB/MS (jako když se konfiguruje multi-seat)?
24.7.2020 15:49 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
To by šlo, ale mám jen jednu klávesnici a myš. Teda mám v šuplíku i další, ale používat 2 klávesnice a myši by pro mě bylo nepohodlné.
24.7.2020 16:24 MadCatX | skóre: 28 | blog: dev_urandom
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Odpovědět | | Sbalit | Link | Blokovat | Admin
Možná bys mohl do xinitrc přidat něco jako
PROCS=$(ps -aux);
TEST=$(echo -n "$PROCS" | grep "Xorg :8");
if [ -n "$TEST" ]; then
    transfer_input.sh
fi
ale je to taky docela hack.
24.7.2020 18:22 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Zkouším, ale nejde. Zkoušel jsem dát do $HOME/.xinitrc i do /etc/X11/xinit/xinitrc. Nenačítá se xinitrc náhodou jen když se Xko startuje příkazem startx? Bumblebee si dané Xko spouští napřímo, takto:
/usr/lib/Xorg :8 -config /etc/bumblebee/xorg.conf.nvidia \
 -configdir /etc/bumblebee/xorg.conf.d -sharevts -nolisten tcp \
 -noreset -verbose 3 -isolateDevice PCI:01:00:0 \
 -modulepath /usr/lib/nvidia/xorg,/usr/lib/xorg/modules
27.7.2020 11:08 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Zkoušel jsem dávat i do adresáře /etc/X11/Xsession.d a do souboru /etc/X11/xinit/xserverrc a taky to nefunguje. Takže tudy cesta nepovede.
27.7.2020 21:50 z_sk | skóre: 34 | blog: analyzy
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
A, /etc/X11/xinit/xinitrc?
debian.plus@protonmail.com
27.7.2020 22:21 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Debiane ty dneska zlobíš :-) To jsem psal o komentáře výše, že jsem "Zkoušel jsem dát do $HOME/.xinitrc i do /etc/X11/xinit/xinitrc."
27.7.2020 11:50 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Odpovědět | | Sbalit | Link | Blokovat | Admin
Díky všem za odpovědi. Zdá se, že systemd v tomto opravdu nepomůže. Škoda, myslel jsem, že když se proces "Xorg :8" vypisuje jako dítě služby bumblebeed.service, tak že systemd nabízí nějakou možnost sledování svých potomků. Stačilo by kdyby systemd měl možnost spustit script ve chvíli kdy se spustí jakokoliv child proces dané služby. V tom scriptu by se jen otestovalo jméno child procesu (nebo jiný parametr) a dalo by se s tím krásně pracovat. Asi jsem moc náročný :-)
27.7.2020 17:24 MadCatX | skóre: 28 | blog: dev_urandom
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Ještě bys mohl zkusit pomocí ExecStartPost pustít skript, který počká, dokud druhý Xorg nenastartuje a pak překonfiguruje vstupní zařízení.
27.7.2020 22:37 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
No jestli tím "počká" myslíš to že ten script bude ve smyčce kontrolovat ps aux | grep "Xorg :8", tak to mi moc nepomůže, protože služba bumblebeed.service se spouští hned při startu PC takže to bych ten script, který bude ve smyčce kontrolovat mohl zrovna spustit po nabootování a vyšlo by to nastejno.

Asi to udělám tak, že vytvořím wraper "muj_optirun.sh" o kterém jsem psal navrchu téhle diskuze. Stejně potřebuji při prvním spuštění "Xorg :8" spustit i windows manager, tak to dám všechno do toho wraperu. Zdá se mi to asi nejelegantnější řešení pokud to pomocí systemd nejde.
28.7.2020 08:43 MadCatX | skóre: 28 | blog: dev_urandom
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Rozdíl je v tom, že takhle ten skript může čekat jen na začátku, provést, co potřebuješ a skončit a při restartu bumblebeed se spustí znovu. Tohle by se ti s nějakým improvizovaným daemonem dělalo komplikovaně. Wrappnout si optirun je podle mě OK řešení.
28.7.2020 09:43 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Jenomže služba bumblebeed jede pořád (od nabootování až do vypnutí PC). Aby ten ExecStartPost fungoval, tak bych musel pokaždé když ukončím aplikaci spuštěnou přes "optirun" (a tím skončí i proces "Xorg :8") resetovat bumblebeed ručně.
Gréta avatar 28.7.2020 07:45 Gréta | skóre: 37 | blog: Grétin blogísek | 🇮🇱==❤️ , 🇵🇸==💩 , 🇪🇺==☭
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Odpovědět | | Sbalit | Link | Blokovat | Admin

<fuj>optirun taky dělá že bumblebeed votevře socket byse toho možná dalo využít :O :O

ss | grep bum
u_str ESTAB      0      0                               /var/run/bumblebee.socket

</fuj>

Zelená energetická soustava založená na obnovitelnejch zdrojích energie versus realnej svět 🤡🇪🇸
28.7.2020 09:00 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Jo máš pravdu, dokonce 2 sokety si to otevře.

Když jsem už před tím hledal, tak jsem u systemd narazil na možnost ověřovat zda existuje soubor:
[Unit]
ConditionPathExists=/etc/sysconfig/cloudformation
ale mělo by to ověřovat jen při startu služby a přidávat k tomu timery bych dosáhl stejného efektu jako kdyby to kontroloval bash script ve smyčce. Ale existuje Path unit , která interně využívá inotify. Tohle se mi nezdá být až tak fuj. Nebo je na inotify (Path_unit) něco špatného?
28.7.2020 13:22 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Tak tahle varianta, také asi padá. Vytvořil jsem *.path i *.service podle tohoto návodu, ale nefunguje to. Přesněji funguje to u normálního souboru, např. /var/tmp/test.txt, ale u /var/run/bumblebee.socket to nejde. Jak jsem googlil, tak sockety se neberou jako normální soubory, které inotify monitoruje.

...a jestli bych měl ve smyčce kontrolovat jesli existuje /var/run/bumblebee.socket nebo ps aux | grep "Xorg :8", tak to vyjde nastejno.
28.7.2020 13:33 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
...ale moment, teď vidím, že Xko si vytváří i soubor /tmp/.X11-unix/X8. Jo to už *.path (inotify) zachytí a funguje to. Pokud se na jméno tohoto souboru dá spolehnout, tak takhle by to šlo.
28.7.2020 21:15 GeorgeWH | skóre: 42
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
... a pritom to je tiez socket.
28.7.2020 21:22 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
jj, napsal jsem to špatně. Zkrátka když je to v adresáři /var/run/ tak to nefunguje. Zkoušel jsem to i na jiných socketech v tom adresáři. Ale na tom /tmp/.X11-unix/X8 to funguje.
Řešení 2× (Bherzet, Vantomas)
31.7.2020 10:57 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Dám zde řešení, které se pro můj případ zdá být jednoduché a spolehlivé a mělo by fungovat nejen ve spojení s Bumblebee, ale i s jinými GPU ovladači. Dalo by se upravit i tak, aby se kbd a mouse vyply při vytvoření každého nového displeje (/tmp/.X11-unix/X*) kromě primárního (/tmp/.X11-unix/X0):

$ cat ~/.config/systemd/user/bumblebee.path
[Unit]
Description=Monitors whether /tmp/.X11-unix/X8 file (socket) exists.

[Path]
PathExists=/tmp/.X11-unix/X8
Unit=bumblebee-disable-kbd-mouse.service

[Install]
WantedBy=multi-user.target
$ cat ~/.config/systemd/user/bumblebee-disable-keyb-mouse.service
[Unit]
Description=Executes script when a file (/tmp/.X11-unix/X8) defined in the bumblebee.path file exists.

[Service]
Type=simple
ExecStartPre=/bin/sleep 1
ExecStart=/path/to/script/disable-kbd-mouse-xorg-8.sh

[Install]
WantedBy=multi-user.target
$ systemctl --user enable bumblebee.path
28.7.2020 10:57 z_sk | skóre: 34 | blog: analyzy
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Odpovědět | | Sbalit | Link | Blokovat | Admin
Nechces si radsej upravit zdrojaky toho programu - bumblebee ci bumblebee deamon, aby spustil skript, tak ako chces?

V debiane je preklad balika easy (vid).
debian.plus@protonmail.com
28.7.2020 13:16 LarryL | skóre: 27
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Překompilovat zdrojáky mě taky napadlo, ale ze všech variant, které tu padly mě to přijde asi nejsložitější. Používám rolling-release, takže bych musel překompilovávat často nebo to vynechvat z aktualizace.
28.7.2020 17:51 z_sk | skóre: 34 | blog: analyzy
Rozbalit Rozbalit vše Re: Jak spustit proces když systemd spustí konkrétní proces
Ved tu upravu dostan do upstreamu.
debian.plus@protonmail.com

Založit nové vláknoNahoru

Tiskni Sdílej: Linkuj Jaggni to Vybrali.sme.sk Google Del.icio.us Facebook

ISSN 1214-1267, (c) 1999-2007 Stickfish s.r.o.