doc:appunti:linux:sa:systemd
Differences
This shows you the differences between two versions of the page.
Both sides previous revisionPrevious revisionNext revision | Previous revision | ||
doc:appunti:linux:sa:systemd [2017/11/07 09:51] – [OpenVPN con systemd] niccolo | doc:appunti:linux:sa:systemd [2023/12/13 12:37] (current) – [Alternatriva allo script rc.local] niccolo | ||
---|---|---|---|
Line 1: | Line 1: | ||
====== Systemd ====== | ====== Systemd ====== | ||
+ | **[[wp> | ||
===== Comandi di servizio ===== | ===== Comandi di servizio ===== | ||
- | Quando si modifica qualche file di configurazione (ad esempio gli script | + | Quando si modifica qualche file di configurazione (ad esempio gli //unit files// |
< | < | ||
Line 79: | Line 80: | ||
</ | </ | ||
- | ===== Unit, file, ... ===== | + | ===== Unit file, service, device, target, ... ===== |
+ | |||
+ | Nella terminologia di //systemd// una **unit** è genericamente una risorsa che il sistema sa gestire. Tali risorse sono definite da alcuni file chiamati appunto **unit file**. | ||
+ | |||
+ | Gli //unit file// vengono installati dai vari pacchetti nella directory **/ | ||
+ | |||
+ | * **/ | ||
+ | * **/ | ||
+ | * **/ | ||
+ | |||
+ | Uno //unit file// può descrivere diversi tipi di risorsa, indicato dall' | ||
+ | |||
+ | ^ .service | In genere una applicazione (demone) che fornisce un servizio. Contiene informazioni su quando attivarla, le dipendenze, ecc. | | ||
+ | ^ .device | ||
+ | ^ .taget | ||
===== Servizi enabled, disabled, masked, ... ===== | ===== Servizi enabled, disabled, masked, ... ===== | ||
Line 85: | Line 100: | ||
Le due condizioni più comuni per un servizio sono **enabled** o **disabled**, | Le due condizioni più comuni per un servizio sono **enabled** o **disabled**, | ||
- | La condizione **masked** di alcuni **file** è equivalente a // | + | La condizione **masked** di alcuni **unit file** è equivalente a // |
+ | |||
+ | ===== Starting a service when a filesystem is available an mounted ===== | ||
+ | |||
+ | This solution was tested on **Debian 9 Stretch**. | ||
+ | |||
+ | We have a filesystem on an **external USB disk**, which is not guaranteed to be present at bootstrap; to avoid hangs or errors during bootstrap, we have the following in **/ | ||
+ | |||
+ | < | ||
+ | PARTUUID=92e84ecd-a306-44df-929b-... /data ext4 auto, | ||
+ | </ | ||
+ | |||
+ | If the USB disk is not plugged during bootstrap, the filesystem is not mounted and there are not blocking errors (due the **nofail** option). We want to start a service (actually the Kodi Media Center) only if the filesystem is mounted. The relevant lines in the unit file **/ | ||
+ | |||
+ | < | ||
+ | # See man systemd.unit for the following directives. | ||
+ | # This is equivalent of placing an " | ||
+ | RequiresMountsFor = /data | ||
+ | # When systemd starts or stops " | ||
+ | PartOf = data.mount | ||
+ | </ | ||
+ | |||
+ | In this way, the Kodi service is not started if the USB disk is not connected. If the device is connected at a later time, the filesystem is automatically mounted and the Kodi service is automatically started. | ||
+ | |||
+ | |||
+ | ===== Modificare Ctrl-Alt-Del con Systemd ===== | ||
+ | |||
+ | Con il vecchio sistema di init **sysvinit** l' | ||
+ | |||
+ | Nelle nuove versioni di Debian si utilizza **systemd** per l'init del sistema, il vecchio file di configurazione non esiste più. Ecco come associare un **poweroff** invece di un **reboot**: | ||
+ | |||
+ | < | ||
+ | ln -s / | ||
+ | </ | ||
+ | |||
+ | === Spiegazione === | ||
+ | |||
+ | Le operazioni predefinite sono definite dai file contenuti in **/ | ||
+ | |||
+ | < | ||
+ | ctrl-alt-del.target -> reboot.target | ||
+ | </ | ||
+ | |||
+ | Non è necessario modificare il contenuto di questa directory, si può fare un override creando il link simbolico opportuno nella directory **/ | ||
+ | ===== Timeout in attesa di un device ===== | ||
+ | |||
+ | Può capitare che il processo di **bootstrap fallisce** perché un device elencato in **/ | ||
+ | |||
+ | < | ||
+ | / | ||
+ | </ | ||
+ | |||
+ | ===== Verifica Servizi ===== | ||
+ | |||
+ | Alcuni comandi utili per **verificare il funzionamento** dei servizi gestiti da **systemd**. | ||
+ | |||
+ | Mostra lo stato di tutti i **servizi** e di tutte le **unit**: | ||
+ | |||
+ | < | ||
+ | systemctl --all --full status | ||
+ | </ | ||
+ | |||
+ | Mostra le **unit** // | ||
+ | |||
+ | < | ||
+ | systemctl --all list-dependencies ntp.service | ||
+ | </ | ||
+ | |||
+ | ===== Alternativa allo script rc.local ===== | ||
+ | |||
+ | Come eseguire uno script all' | ||
+ | |||
+ | Creare una unit Systemd **/ | ||
+ | |||
+ | < | ||
+ | # / | ||
+ | # | ||
+ | # Service executed once the system has reached the multi-user status. | ||
+ | # | ||
+ | # Type=oneshot | ||
+ | # RemainAfterExit=yes | ||
+ | # when all its processes exited. | ||
+ | # | ||
+ | # Eanble the service with: | ||
+ | # | ||
+ | |||
+ | [Service] | ||
+ | Type=oneshot | ||
+ | RemainAfterExit=yes | ||
+ | ExecStart=/ | ||
+ | |||
+ | [Install] | ||
+ | WantedBy=multi-user.target | ||
+ | </ | ||
+ | |||
+ | Abilitare la unit e predisporre lo script **/ | ||
+ | |||
+ | ===== Riferimenti web ===== | ||
+ | * **[[https:// | ||
+ | Understanding Systemd Units and Unit Files]]** | ||
+ | * **[[https:// |
doc/appunti/linux/sa/systemd.1510044710.txt.gz · Last modified: 2017/11/07 09:51 by niccolo