< Systemd (Italiano)

systemd (Italiano)/User (Italiano)

systemd offre agli utenti la possibilità di gestire i servizi sotto il controllo dell'utente tramite una istanza di systemd per singolo utente, che consente agli stessi di avviare, fermare, abilitare e disabilitare le proprie unità. Questa caratteristica è utile per demoni e altre operazioni automatiche come lo scaricamento della posta. È inoltre possibile, con alcune modifiche, avviare Xorg e il window manager in uso direttamente tramite i servizi utente.

Come funziona

Secondo la configurazione di default in /etc/pam.d/system-login, il modulo pam_systemd avvia automaticamente una istanza di systemd --user al primo login dell'utente. Tale processo rimarrà in esecuzione fin tanto che l'utente sarà coneesso, e verrà terminato quando l'utente effettua il logout. Quando l'#Avvio automatico delle istanze utente di systemd è abilitato, l'istanza viene avviata al boot e non più terminata. L'istanza utente di systemd si occupa di gestire i servizi utente, utilizzabili per avviare demoni o compiere operazioni automatiche, disponendo comunque di tutti i benefici di systemd, come l'attivazione socket, timers, dipendenze o controllo processi tramite cgroups. Similmente a quanto accade con in servizi di sistema, i servizi utente risiedono nelle directory seguenti (ordinate per preferenza crescente):

  • /usr/lib/systemd/user/ directory per i servizi forniti dai pacchetti.
  • directory per i servizi definiti dall'amministratore di sistema.
  • directory per i servizi utente.

All'avvio di una istanza utente di systemd, viene caricato il target ; è ora possibile controllare manualmente i servizi utente tramite .

Attenzione:
  • Si noti che, a partire dalla versione 206, l'istanza utente systemd --user è un processo dedicato per utente, e non per sessione. Ne consegue che la maggior parte delle risorse gestite dai servizi utenti, come sockets o file di stato, riguardano un singolo utente (sono difatti situati nella home directory dello stesso) e non una sessione. Ciò significa che tutti i servizi utente vengono eseguiti al di fuori di una sessione; per questo motivo, i programmi che necessitano di essere eseguiti per ogni singola sessione probabilmente non funzioneranno con le istanze utente di systemd. La gestione delle sessioni da parte di systemd varia continuamente. Si legga e per avere un'idea generale sullo sviluppo di questa funzionalità.
  • systemd --user viene eseguito come processo separato rispetto a systemd --system. I servizi utente non possono pertanto riferirsi o dipendere da servizi di sistema.

Configurazione di base

Tutti i servizi utente devono essere inseriti in ~/.config/systemd/user. Se si vuole avviare une servizio automaticamente al login, si esegua per ogni servizio.

D-Bus

Alcune applicazioni necessitano di un messagebus D-Bus, tradizionalmente avviato quando si esegue un desktop environment tramite . A partire dalla versione 226, systemd è divenuto il gestore del messagebus utente. Il demone dbus-daemon viene avviato una volta per ogni sessione utente utilizzando le unità utente e .

Variabili d'ambiente

L'istanza utente di systemd non eredita le variabili d'ambiente definite in e similari. Vi sono quattro modi per definire variabili d'ambiente per istanze utente di systemd:

  1. Per gli utenti che abbiano una propria home directory, si specifichi l'opzione in . Viene applicata solo alle unità utente di un utente specifico.
  2. Utilizzare l'opzione in /etc/systemd/user.conf. Viene applicata a tutti i servizi utente.
  3. Creare un file di configurazione in . Viene applicata a tutti i servizi utente.
  4. In qualsiasi momento, tramite i comandi o systemctl --user import-environment. Applicata a tutti i servizi avviati dopo l'esecuzione dei comandi di cui sopra, ma non a quelli già avviati.

Una variabile che si potrebbe voler definire è .

DISPLAY e XAUTHORITY

La variabile viene utilizzata da qualsiasi applicazione X per individuare il display da utilizare, mentre identifica il percorso al file dell'utente corrente, e di conseguenza il cookie necessario per accedere a X. Se si intende lanciare applicazioni grafiche tramite servizi di systemd, sarà necessario definire tali variabili. A partire dalla versione 219, systemd fornisce uno script situato in per importarle nella sessione utente di systemd all'avvio di X. Ne consegue che, a meno che X non venga avviato tramite procedure non standard, i servizi utenti dovrebbero essere già al corrente dei valori delle due variabili.

PATH

Come tutte le variabili d'ambiente definite tramite o , anche non è visibile a systemd. Se si modifica il valore di tale variabile e si intende avviare applicazioni che se ne avvalgano come servizi di systemd, sarà necessario notificare systemd della sua modifica. È consigliabile farlo aggiungendo la seguente riga al proprio , dopo aver definito la variabile :

~/.bash_profile
systemctl --user import-environment PATH

Avvio automatico delle istanze utente di systemd

L'istanza utente di systemd viene avviata dopo il primo login di un utente, e fermata alla chiusura dell'ultima sessione di quell'utente. Potrebbe essere talvolta necesario avviarla subito dopo il boot, e mantenerla attiva alla chiusura dell'ultima sessione utente relativa, ad esempio per avere processi utente attivi senza alcuna sesione utente in corso. Si esegua a tal proposito il seguente comando per abilitare tale comportamento per un singolo utente:

# loginctl enable-linger nomeutente

Xorg e systemd

Vi sono diversi metodi per avviare Xorg tramite systemd. Di seguito due possibilità: l'avvio di una sessione utente con un processo di Xorg o l'avvio di quest'ultimo come servizio utente.

Login automatico in Xorg senza display manager

Quanto sotto avvierà una sessione utente ed il server Xorg come unità di sistema e provvederà poi a leggere il contenuto di , avviare il window manager, ecc.

Sarà necessario configurare #D-Bus nel modo corretto ed installare il pacchetto .

Si crei il proprio file xinitrc da quello di default, in modo che effettui il source dei files in /etc/X11/xinit/xinitrc.d/. È necessario che l'esecuzione del priorio non ritorni, quindi si inserisca come ultimo comando, o si aggiunga all'ultimo comando (ad esempio, il proprio window manager).

Questa sessione utilizzerà il proprio demone D-Bus, ma varie utility di systemd si connetteranno automaticamente all'istanza avviata dal servizio

Si abiliti infine (come root) il servizio xlogin per ottenere il login automatico al boot:

# systemctl enable xlogin@username

La sessione utente viene eseguita interamente in un ambiente systemd, quindi tutto dovrebbe funzionare nel modo corretto.

Avvio di Xorg come servizio utente

In alternativa, è possibile avviare xorg come servizio utente, avendo il vantaggio di poter definire il servizio in questione come dipendenza di altre unità che lo necessitino. Questo approccio, tuttavia, non è esente da difetti, elencati sotto:

A partire dalla versione 1.16, si integra in modo migliore con systemd in due modi:

  • Può essere avviato senza privilegi di root, delegando la gestione dei dispositivi a logind (si vedano i commit di Hans de Goede this qui).
  • Può essere avviato come servizio attivato tramite socket (si veda questo commit).

Sfortunatamente, per avviare Xorg senza privilegi di amministratore, è necessario essere in una sessione, perciò, in questo momento, è necessario avviare Xorg come amministratore per poterlo gestire tramite i servizi utente (come per versioni precedenti la 1.16).

Di seguito le istruzioni per avviare Xorg come servizio utente

1. Assicurarsi che Xorg possa venire avviato con privilegi da amministratore da qualsiasi utente, modificando :

/etc/X11/Xwrapper.config
allowed_users=anybody
needs_root_rights=yes

2. Creare le seguenti unità in ~/.config/systemd/user:

Dove } è il terminale virtuale dove Xorg verrà eseguito, definito all'interno del servizio utente, o specificato come variabile d'ambiente in systemd tramite:

$ systemctl --user set-environment XDG_VTNR=1

3. Assicurarsi di definire la variabile d'ambiente come spiegato sopra.

4. Per abilitare l'attivazione socket per Xorg sul display 0 e tty2, si procederebbe come segue:

$ systemctl --user set-environment XDG_VTNR=2     # Per dichiarare a xorg@.service quale terminale utilizzare
$ systemctl --user start xorg@0.socket            # Resta in ascolto sul socket del display 0

A questo punto, qualsiasi applicazione X11 verrà eseguita automaticamente sul terminale virtuale 2.

La variabile d'ambiente può essere definita nell'ambiente di systemd partendo da , cosa che renderebbe possibile avviare qualsiasi applicazione X11, compreso un window manager, come unità utente systemd, inserendo una dipendenza a .

Attenzione: Al momento, l'esecuzione di un window manager come servizio utente ne comporta l'avvio al di fuori della sessione, con tutti i problemi che ciò comporta: General troubleshooting#Session permissions. Sembra però che gli sviluppatori di systemd stiano tentando di rendere possibile tale comportamento. Si veda a tal proposito e .

Scrivere servizi utente

Esempio

Di seguito un esempio per l'avvio di mpd come servizio utente:

Esempio con variabili

Esempio di avvio di come servizio utente, con definizione di una variabile utente per la directory home dove Sickbeard reperisce alcuni file di configurazione:

~/.config/systemd/user/sickbeard.service
[Unit]
Description=SickBeard Daemon

[Service]
ExecStart=/usr/bin/env python2 /opt/sickbeard/SickBeard.py --config %h/.sickbeard/config.ini --datadir %h/.sickbeard

[Install]
WantedBy=default.target

Come specificato in , la variabile viene sostituita con la home directory dell'utente che esegue il servizio. Vi sono altre variabili disponibili, spiegate in dettaglio nelle pagine di manuale di systemd.

Nota per applicazioni X11

La maggior parte delle applicazioni X11, necessitano della variabile per essere eseguite. Vedere a tal proposito la sezione #DISPLAY e XAUTHORITY.

Esempi d'uso

Multiplexer di terminale persistente

You may wish your user session to default to running a terminal multiplexer, such as GNU Screen or Tmux, in the background rather than logging you into a window manager session. Separating login from X login is most likely only useful for those who boot to a TTY instead of to a display manager (in which case you can simply bundle everything you start in with myStuff.target).

To create this type of user session, procede as above, but instead of creating wm.target, create multiplexer.target:

, like above, should start anything you think should run before tmux or screen starts (or which you want started at boot regardless of timing), such as a GnuPG daemon session.

You then need to create a service for your multiplexer session. Here is a sample service, using tmux as an example and sourcing a gpg-agent session which wrote its information to /tmp/gpg-agent-info. This sample session, when you start X, will also be able to run X programs, since DISPLAY is set.

Once this is done, tmux.service, and any services you created to be run by and you should be set to go! Activated as described above, but be sure to remove the from , since your user session will not be taking over a TTY. Congratulations! You have a running terminal multiplexer and some other useful programs ready to start at boot!

Window manager

Per eseguire un window manager come servizio di systemd, sarà necessario avviare Xorg come servizio utente. Di seguito, un esempio utilizzando awesome:

Riferimenti

gollark: horse = monoid in the category of endofunctors
gollark: Idea: do key exchange with HORSE via words.
gollark: What do you mean *solve*?
gollark: I mean, they sold (ad-supported) Kindle Fires for £40.
gollark: I think they try and lock it down because those are sold at (more of) a loss.
This article is issued from Archlinux. The text is licensed under Creative Commons - Attribution - Sharealike. Additional terms may apply for the media files.