Difference between revisions of "Systemd/User (Italiano)"

From ArchWiki
Jump to: navigation, search
m (Articoli correlati)
(flagged broken section links)
(Tag: wiki-scripts)
 
(25 intermediate revisions by 5 users not shown)
Line 4: Line 4:
 
[[en:Systemd/User]]
 
[[en:Systemd/User]]
 
[[es:Systemd/User]]
 
[[es:Systemd/User]]
{{Article summary start|Sommario}}
+
[[fr:Systemd/utilisateur]]
{{Article summary text|Come gestire le sessioni utente di [[systemd (Italiano)|systemd]].}}
+
[[ja:Systemd/ユーザー]]
{{Article summary heading|Articoli collegati}}
+
[[ru:Systemd/User]]
{{Article summary wiki|systemd (Italiano)}}
+
[[zh-cn:Systemd/User]]
{{Article summary end}}
+
{{Related articles start}}
 +
{{Related|systemd (Italiano)}}
 +
{{Related|Automatic login to virtual console (Italiano)}}
 +
{{Related|Start X at Login (Italiano)}}
 +
{{Related articles end}}
  
[[systemd (Italiano)|systemd]] offre agli utenti la possibilità di eseguire un'istanza di systemd per gestire i propri processi e servizi, consentendo di avviare, fermare, abilitare e disabilitare le unità che si trovano in certe directory quando systemd viene eseguito dall'utente. Ciò è utile per demoni e altri servizi che comunemente non vengono avviati da root oppure utilizzano un utente apposito, come avviene con [[mpd (Italiano)|mpd]].
+
[[systemd (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.
  
{{Nota|Le sessioni utente di systemd non sono compatibili con il patchset -ck.}}
+
==Come funziona==
  
==Setup==
+
Secondo la configurazione di default in {{ic|/etc/pam.d/system-login}}, il modulo {{ic|pam_systemd}} avvia automaticamente una istanza di {{ic|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):
  
===startx===
+
* {{ic|/usr/lib/systemd/user/}} directory per i servizi forniti dai pacchetti.
 +
* {{ic|/etc/systemd/user/}} directory per i servizi definiti dall'amministratore di sistema.
 +
* {{ic|~/.config/systemd/user/}} directory per i servizi utente.
  
{{Nota|Questo passaggio non è necessario se si intende utilizzare l'autologin.}}
+
All'avvio di una istanza utente di systemd, viene caricato il target {{ic|default.target}}; è ora possibile controllare manualmente i servizi utente tramite {{ic|systemctl --user}}.
  
Si faccia gestire la propria sessione da {{ic|systemd-logind}}. Se [[systemd (Italiano)|systemd]] è stato eseguito come sistema di init, allora non è necessario compiere alcuna operazione.
+
{{Attenzione|
 +
* Si noti che, a partire dalla versione 206, l'istanza utente {{ic|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 [https://mail.gnome.org/archives/desktop-devel-list/2014-January/msg00079.html] e [http://lists.freedesktop.org/archives/systemd-devel/2014-March/017552.html] per avere un'idea generale sullo sviluppo di questa funzionalità.
 +
* {{ic|systemd --user}} viene eseguito come processo separato rispetto a {{ic|systemd --system}}. I servizi utente non possono pertanto riferirsi o dipendere da servizi di sistema.
 +
}}
  
L'utente dovrà ora lanciare un'istanza di systemd inserendo quanto segue nel proprio {{ic|~/.xinitrc}}:
+
==Configurazione di base==
  
{{bc|systemd --user &}}
+
Tutti i servizi utente devono essere inseriti in {{ic|~/.config/systemd/user}}. Se si vuole avviare une servizio automaticamente al login, si esegua {{ic|systemctl --user enable ''servizio''}} per ogni servizio.
  
Se l'utente non lancia il proprio window manager tramite {{ic|systemd --user}}, sarà invece necessario inserire {{ic|systemd --user &}} in modo da lanciare systemd come qualsiasi altra applicazione prima di eseguire il window manager.
+
===D-Bus===
  
Dopo l'avvio di X, è possibile controllare se la sessione è gestita da {{ic|systemd-logind}} utilizzando il seguente comando:
+
Alcune applicazioni necessitano di un messagebus [[D-Bus]], tradizionalmente avviato quando si esegue un desktop environment tramite {{ic|dbus-launch}}.
 +
A partire dalla versione 226, systemd è divenuto il gestore del messagebus utente. [https://www.archlinux.org/news/d-bus-now-launches-user-buses/] Il demone ''dbus-daemon'' viene avviato una volta per ogni sessione utente utilizzando le unità utente {{ic|dbus.socket}} e {{ic|dbus.service}}.
  
$ loginctl --no-pager show-session $XDG_SESSION_ID | grep Active
+
{{Nota|Se precedentemente si sono creati tali file manualmente nella cartella {{ic|/etc/systemd/user/}} o {{ic|~/.config/systemd/user/}}, è ora possibile rimuoverli.}}
  
Se l'output corrisponde a {{ic|1=Active=yes}}, allora si sta utilizzando {{ic|systemd-logind}} per gestire la sessione. Rimuovere eventuali occorrenze di {{ic|ck-launch-session}} o {{ic|dbus-launch}} dal proprio {{ic|~/.xinitrc}}, dal momento che tali comandi non sono più richiesti.
+
===Variabili d'ambiente===
  
===Display Managers===
+
L'istanza utente di systemd non eredita le [[environment variables|variabili d'ambiente]] definite in {{ic|.bashrc}} e similari. Vi sono quattro modi per definire variabili d'ambiente per istanze utente di systemd:
  
I principali Display Manager utilizzano {{ic|systemd-logind}} di default, perciò il comando {{ic|loginctl}} menzionato nella sezione precedente dovrebbe funzionare come previsto. Sarà semplicemente necessario aggiungere {{ic|systemd --user}} all'elenco dei programmi che l'ambiente desktop avvia automaticamente.
+
# Per gli utenti che abbiano una propria home directory, si specifichi l'opzione {{ic|DefaultEnvironment}} in {{ic|~/.config/systemd/user.conf}}. Viene applicata solo alle unità utente di un utente specifico.
 +
# Utilizzare l'opzione {{ic|DefaultEnvironment}} in {{ic|/etc/systemd/user.conf}}. Viene applicata a tutti i servizi utente.
 +
# Creare un file di configurazione in {{ic|/etc/systemd/system/user@.service.d/}}. Viene applicata a tutti i servizi utente.
 +
# In qualsiasi momento, tramite i comandi {{ic|systemctl --user set-environment}} o {{ic|systemctl --user import-environment}}. Applicata a tutti i servizi avviati dopo l'esecuzione dei comandi di cui sopra, ma non a quelli già avviati.
 +
:: {{Suggerimento|1=Per definire più variabili contemporaneamente, si crei un file di configurazione contentente una lista di coppie ''chiave=valore'', separate da uno spazio, e si aggiunga {{ic|xargs systemctl --user set-environment < /path/to/file.conf}} al file di configurazione utente della shell in uso.}}
  
====GNOME 3 (Utilizzando GDM)====
+
Una variabile che si potrebbe voler definire è {{ic|PATH}}.
  
Gli utenti che desiderano che GDM 3 avvii automaticamente la propria sessione di {{ic|systemd --user}} devono semplicemente creare una sessione di login speciale:
+
====DISPLAY e XAUTHORITY====
  
{{hc|/usr/share/xsessions/gnome-systemd.desktop|<nowiki>
+
La variabile {{ic|DISPLAY}} viene utilizzata da qualsiasi applicazione X per individuare il display da utilizare, mentre {{ic|XAUTHORITY}} identifica il percorso al file {{ic|.Xauthority}} 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.
[Desktop Entry]
+
A partire dalla [http://cgit.freedesktop.org/systemd/systemd/tree/NEWS?id=v219#n194 versione 219], systemd fornisce uno script situato in {{ic|/etc/X11/xinit/xinitrc.d/50-systemd-user.sh}} 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.
Type=Application
+
Name=systemd
+
Comment=Avvia un'istanza utente di 'systemd'
+
Exec=/usr/lib/systemd/systemd --user
+
</nowiki>}}
+
  
Assicurarsi di scegliere la sessione {{ic|systemd}} al login.
+
====PATH====
  
{{Nota|Quanto sopra è stato testato con una installazione pura di GNOME 3 e GDM. In caso di configurazioni alternative, la vostra esperienza potrebbe variare. Questo metodo non richiede l'installazione degli script user-session di systemd.}}
+
Come tutte le variabili d'ambiente definite tramite {{ic|.bashrc}} o {{ic|.bash_profile}}, anche {{ic|PATH}} 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 {{ic|.bash_profile}}, dopo aver definito la variabile {{ic|PATH}}:
  
===Utilizzare {{ic|systemd --user}} per gestire la propria sessione===
+
{{hc|~/.bash_profile|<nowiki>
 
+
systemctl --user import-environment PATH
Systemd ha molte caratteristiche utili, una delle quali è la capacità di tracciare i programmi utilizzando i cgroups (si esegua {{ic|systemctl status}}). Benchè ciò sia veramente utile per un sistema di init il cui processo ha '''pid 1''', anche la modalità utente può avvalersi di questa caratteristica per avviare automaticamente i programmi dello stesso, tracciando al tempo stesso il contenuto di ogni cgroup.
+
 
+
Tutte le units dell'utente andranno inserite in {{ic|$HOME/.config/systemd/user}} ed avranno la precedenza sulle altre unità contenute nelle directory di sistema.
+
 
+
Sarà necessario installare due pacchetti per avvalersi di questa funzionalità, entrambi reperibili su [[AUR (Italiano)|AUR]]: {{Aur|xorg-launch-helper}} e {{Aur|user-session-units}}, se si desidera utilizzare l'autologin.
+
 
+
Inizializzare quindi i propri targets. È consigliabile crearne due: una per il window manager e l'altra come target di default. Il target del window manager dovrebbe essere simile al seguente:
+
 
+
{{hc|$HOME/.config/systemd/user/wm.target|<nowiki>
+
[Unit]
+
Description=Window manager target
+
Wants=xorg.target
+
Wants=mystuff.target
+
Requires=dbus.socket
+
AllowIsolate=true
+
 
+
[Install]
+
Alias=default.target
+
 
</nowiki>}}
 
</nowiki>}}
  
Si crei un secondo target chiamato {{ic|mystuff.target}}, che andrà poi inserito nel campo {{ic|WantedBy}} (sezione {{ic|[Install]}}) di tutti i servizi che si intende avviare ad eccezione del window manager:
+
===Avvio automatico delle istanze utente di systemd===
  
{{hc|$HOME/.config/systemd/user/mystuff.target|<nowiki>
+
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.
[Unit]
+
Si esegua a tal proposito il seguente comando per abilitare tale comportamento per un singolo utente:
Description=Xinitrc Stuff
+
Wants=wm.target
+
  
[Install]
+
# loginctl enable-linger ''nomeutente''
Alias=default.target
+
</nowiki>}}
+
  
Si crei un link simbolico di nome {{ic|default.target}}, che punta al target di cui sopra. Quando si esegue {{ic|systemd --user}}, questo sarà il target avviato.
+
{{Attenzione|I servizi systemd '''non''' sono sessioni, dal momento che vengono eseguiti al di fuori di ''logind''. Non si utilizzi la funzionalità di lingering per abilitare il login autometico, dal momento che questo [[General troubleshooting#Session permissions|renderà inutilizzabile la sessione]].}}
  
Infine, si scrivano i vari files .service corrispondenti ai servizi da avviare. Si inizi con quello del window manager:
+
==Xorg e systemd==
  
{{hc|$HOME/.config/systemd/user/mystuff.target|<nowiki>
+
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.
[Unit]
+
Description=your window manager service
+
Before=mystuff.target
+
After=xorg.target
+
Requires=xorg.target
+
+
[Service]
+
Requires=xorg.target
+
#Environment=PATH=decommentare:per:sovrascrivere:PATH
+
Environment=DISPLAY=:0
+
ExecStart=/percorso/assoluto/ad/eseguibile/wm
+
Restart=always
+
RestartSec=10
+
+
[Install]
+
WantedBy=wm.target
+
</nowiki>}}
+
  
{{Nota|La sezione {{ic|[Install]}} include il valore {{ic|WantedBy}}, che permetterà al servizio di essere linkato come {{ic|$HOME/.config/systemd/user/wm.target.wants/VOSTRO_WM.service}}, quando si utilizza {{ic|systemd --user enable}}, consentendone l'avvio al login. È consigliabile abilitare questo servizio con systemctl e non linkarlo manualmente.}}
+
===Login automatico in Xorg senza display manager===
  
È ora possibile riempire la directory delle unità con tutti i servizi di cui si potrebbe aver bisogno, come ad esempio '''mpd, gpg-agent, offlineimap, parcellite, pulse, tmux, urxvtd, xbindkeys''' e '''xmodmap'''.
+
{{Accuracy|Questa configurazione avvia due istanze di D-Bus: una per il desktop e l'altra per systemd. Perchè non utilizzare quella di systemd? }}
  
===Login automatico===
+
Quanto sotto avvierà una sessione utente ed il server Xorg come unità di sistema e provvederà poi a leggere il contenuto di {{ic|~/.xinitrc}}, avviare il window manager, ecc.
  
Se si vuole utilizzare il login automatico al boot, è possibile utilizzare la relativa unit fornita dal pacchetto {{Aur|user-session-units}}. Si consideri l'idea di abilitare uno screen locker per evitare che qualcuno possa avvalersi della sessione appena avviata.
+
Sarà necessario configurare [[#D-Bus]] nel modo corretto ed installare il pacchetto {{AUR|xlogin-git}}.
  
Se si è installato il pacchetto {{Aur|user-session-units}}, sarà necessario copiare {{ic|/usr/lib/systemd/system/user-session@.service}} in {{ic|/etc/systemd/system/user-session@nomeutente.service}} e modificare queste linee:
+
Si crei il proprio file [[xinitrc (Italiano)|xinitrc]] da quello di default, in modo che effettui il source dei files in {{ic|/etc/X11/xinit/xinitrc.d/}}. È necessario che l'esecuzione del priorio {{ic|~/.xinitrc}} non ritorni, quindi si inserisca {{ic|wait}} come ultimo comando, o si aggiunga {{ic|exec}} all'ultimo comando (ad esempio, il proprio window manager).
  
{{bc|1=Environment=XDG_RUNTIME_DIR=/run/user/%I
+
Questa sessione utilizzerà il proprio demone D-Bus, ma varie utility di systemd si connetteranno automaticamente all'istanza avviata dal servizio {{ic|dbus.service}}
Environment=DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/%I/dbus/user_bus_socket}}
+
  
In:
+
Si abiliti infine ('''come root''') il servizio ''xlogin'' per ottenere il login automatico al boot:
  
{{bc|1=Environment=XDG_RUNTIME_DIR=/run/user/%U
+
# systemctl enable xlogin@''username''
Environment=DBUS_SESSION_BUS_ADDRESS=unix:path=/run/user/%U/dbus/user_bus_socket}}
+
  
{{Nota|Si noti la modifica di {{ic|%I}} in {{ic|%U}}.}}
+
La sessione utente viene eseguita interamente in un ambiente systemd, quindi tutto dovrebbe funzionare nel modo corretto.
  
Si modifichi anche la sezione {{ic|[Install]}}:
+
===Avvio di Xorg come servizio utente===
  
[Install]
+
In alternativa, è possibile avviare [[xorg (Italiano)|xorg]] come servizio utente, avendo il vantaggio di poter definire il servizio in questione come dipendenza di altre unità che lo necessitino.
WantedBy=graphical.target
+
Questo approccio, tuttavia, non è esente da difetti, elencati sotto:
  
O, se non si utilizza un login manager:
+
A partire dalla versione 1.16, {{Pkg|xorg-server}} 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 [http://cgit.freedesktop.org/xorg/xserver/commit/?id=82863656ec449644cd34a86388ba40f36cea11e9 this qui]).
 +
* Può essere avviato come servizio attivato tramite socket (si veda [http://cgit.freedesktop.org/xorg/xserver/commit/?id=b3d3ffd19937827bcbdb833a628f9b1814a6e189 questo commit]).
  
[Install]
+
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).
WantedBy=getty.target
+
  
Si aggiunga questa linea ai files {{ic|/etc/pam.d/login}} e {{ic|/etc/pam.d/system-auth}}:
+
{{Nota|Si noti che quanto sopra non è una restrizione imposta da logind: Xorg necessita infatti di sapere di quale sessione appropriarsi e, ad ora, ottiene questa informazione chiamando la funzione {{ic|GetSessionByPID}} di [http://www.freedesktop.org/wiki/Software/systemd/logind logind], utilizzando il proprio PID come argomento. Si vedano [http://lists.x.org/archives/xorg-devel/2014-February/040476.html questo thread] e [http://cgit.freedesktop.org/xorg/xserver/tree/hw/xfree86/os-support/linux/systemd-logind.c i sorgenti di Xorg]. È probabilmente possibile modificare Xorg in modo che ottenga la sessione dalla tty sulla quale viene avviata.}}
  
session    required    pam_systemd.so
+
Di seguito le istruzioni per avviare Xorg come servizio utente
  
Dal momento che {{ic|user-session@.service}} viene avviato sulla tty1, sarà necessario aggiungere {{ic|1=Conflicts=getty@tty1.service}} al .service in questione, se non è già presente.
+
1. Assicurarsi che Xorg possa venire avviato con privilegi da amministratore da qualsiasi utente, modificando {{ic|/etc/X11/Xwrapper.config}}:
  
Una volta fatto quanto sopra, si esegua {{ic|systemctl --user enable}} {{ic|WM_SCELTO.service}}
+
{{hc|/etc/X11/Xwrapper.config|<nowiki>
 +
allowed_users=anybody
 +
needs_root_rights=yes
 +
</nowiki>}}
  
Una delle cose più importanti da aggiungere ai propri .service è l'utilizzo di {{ic|1=Before=}} e {{ic|1=After=}} nella sezione {{ic|[Unit]}}, che permettono di determinare l'ordine di avvio dei servizi.
+
2. Creare le seguenti unità in {{ic|~/.config/systemd/user}}:
Si supponga di disporre di una applicazione grafica che si vuole avviare al boot: sarà possibile farlo aggiungendo {{ic|1=After=xorg.target}} al proprio .service.
+
Si supponga inoltre di voler avviare {{ic|ncmpcpp}} che richiede {{ic|mpd}} per funzionare: in tal caso si dovrà aggiungere {{ic|1=After=mpd.service}} al .service di {{ic|ncmpcpp}}.
+
  
Col tempo e l'esperienza si capirà come gestire l'ordine di avvio delle applicazioni, oppure leggendo le pagine di man di systemd. Iniziare con [http://www.freedesktop.org/software/systemd/man/systemd.unit.html systemd.unit(5)] è una buona idea.
+
{{hc|~/.config/systemd/user/xorg@.socket|<nowiki>
 +
[Unit]
 +
Description=Socket for xorg at display %i
  
===Altri casi d'uso===
+
[Socket]
 +
ListenStream=/tmp/.X11-unix/X%i
 +
</nowiki>}}
  
====Multiplexer di terminale persistente====
+
{{hc|~/.config/systemd/user/xorg@.service|<nowiki>
 +
[Unit]
 +
Description=Xorg server at display %i
  
Si potrebbe voler utilizzare la propria sessione utente per avviare un multiplexer di terminale come [[GNU Screen|GNU Screen]] o [[Tmux|Tmux]] in background invece di una sessione grafica. La separazione del login dal login grafico è probabilmente utile solamente per gli utenti che effettuano il boot in TTY invece di utilizzare un display manager (nel cui caso è possibile inserire tutti i programmi da avviare nel target {{ic|mystuff.target}}).
+
Requires=xorg@%i.socket
 
+
After=xorg@%i.socket
Per creare questo tipo di sessione utente si proceda come sopra, creando però {{ic|multiplexer.target}} invece di {{ic|wm.target}}:
+
 
+
[Unit]
+
Description=Terminal multiplexer
+
Documentation=info:screen man:screen(1) man:tmux(1)
+
After=cruft.target
+
Wants=cruft.target
+
+
[Install]
+
Alias=default.target
+
 
+
Il target {{ic|cruft.target}}, similmente a {{ic|mystuff.target}}, dovrebbe occuparsi dell'avvio di tutti quei programmi che si pensa debbano essere lanciati prima di tmux o screen (o che si intende avviare al boot indifferentemente dal momento di avvio), come una sessione demone di GnuPG.
+
 
+
Sarà quindi necessario creare un servizio per la propria sessione multiplexer. Di seguito un servizio di esempio che utilizza tmux ed effettua il source di una sessione di gpg-agent che scrive le proprie informazioni in {{ic|/tmp/gpg-agent-info}}. La sessione proposta è inoltre in grado di avviare programmi grafici previo avvio del server X, dal momento che la variabile {{ic|DISPLAY}} è impostata.
+
 
+
{{bc|<nowiki>
+
[Unit]
+
Description=tmux: A terminal multiplixer Documentation=man:tmux(1)
+
After=gpg-agent.service
+
Wants=gpg-agent.service
+
  
 
[Service]
 
[Service]
Type=forking
+
Type=simple
ExecStart=/usr/bin/tmux start
+
SuccessExitStatus=0 1
ExecStop=/usr/bin/tmux kill-server
+
Environment=DISPLAY=:0
+
EnvironmentFile=/tmp/gpg-agent-info
+
  
[Install]
+
ExecStart=/usr/bin/Xorg :%i -nolisten tcp -noreset -verbose 2 "vt${XDG_VTNR}"
WantedBy=multiplexer.target
+
 
</nowiki>}}
 
</nowiki>}}
  
Una volta fatto, si esegua {{ic|systemctl --user activate}} su {{ic|tmux.service}}, {{ic|multiplexer.target}} ed eventuali altri servizi che debbano essere avviati da cruft.target. Si abiliti inoltre {{ic|user-session@.service}} come spiegato sopra, ma assicurarsi di rimuovere la linea {{ic|1=Conflicts=getty@tty1.service}}, dal momento che la propria sessione utente non gestirà una TTY.
+
Dove {{ic|${XDG_VTNR}}} è il terminale virtuale dove Xorg verrà eseguito, definito all'interno del servizio utente, o specificato come variabile d'ambiente in systemd tramite:
  
Congratulazioni! Si dispone ora di un multiplexer di terminale ed altri programmi utili che vengono avviati automaticamente al boot!
+
$ systemctl --user set-environment XDG_VTNR=1
  
=====Avviare X=====
+
{{Nota|Xorg dovrebbe essere lanciato dallo stesso terminale virtuale dove si è effettuato il login, altrimenti loging considererà la sessione come inattiva.}}
  
Si avrà notato che, essendo il multiplexer di terminale il nuovo {{ic|default.target}}, X non sarà avviato automaticamente al boot. Per avviare X, si proceda come sopra ma non si attivi o linki manualmente {{ic|wm.target}} a {{ic|default.target}}, bensì utilizzare un semplice alias per {{ic|startx}}:
+
3. Assicurarsi di definire la variabile d'ambiente {{ic|DISPLAY}} come spiegato [[#DISPLAY|sopra]]{{Broken section link}}.
  
alias startx='systemctl --user start wm.target'
+
4. Per abilitare l'attivazione socket per Xorg sul display 0 e tty2, si procederebbe come segue:
  
==Servizi Utente==
+
$ 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
  
Gli utenti possono ora interagire con le unità poste nelle seguenti directory proprio come farebbero con i servizi di sistema (ordinate in modo ascendente di preferenza):
+
A questo punto, qualsiasi applicazione X11 verrà eseguita automaticamente sul terminale virtuale 2.
  
* {{ic|/usr/lib/systemd/user/}}
+
La variabile d'ambiente {{ic|XDG_VTNR}} può essere definita nell'ambiente di systemd partendo da  {{ic|.bash_profile}}, cosa che renderebbe possibile avviare qualsiasi applicazione X11, compreso un window manager, come unità utente systemd, inserendo una dipendenza a {{ic|xorg@0.socket}}.
* {{ic|/etc/systemd/user}}
+
* {{ic|~/.config/systemd/user}}
+
  
Per controllare l'istanza di systemd, si utilizzi il comando {{ic|systemctl --user}}.
+
{{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 [https://mail.gnome.org/archives/desktop-devel-list/2014-January/msg00079.html] e [http://lists.freedesktop.org/archives/systemd-devel/2014-March/017552.html].}}
  
===Servizi installati da pacchetti===
+
==Scrivere servizi utente==
 
+
I pacchetti che forniscono servizi pensati per essere avviati dall'utente, possono installarli in {{ic|/usr/lib/systemd/user/}}. L'amministratore di sistema può quindi modificare l'unità copiandola in {{ic|/etc/systemd/user/}} e quest'ultima potrà a sua volta essere modificata dall'utente copiandola in {{ic|~/.config/systemd/user}}.
+
  
 
===Esempio===
 
===Esempio===
  
Quanto segue è una versione utente del servizio di mpd:
+
Di seguito un esempio per l'avvio di mpd come servizio utente:
  
{{hc|mpd.service|<nowiki>
+
{{hc|~/.config/systemd/user/mpd.service|<nowiki>
 
[Unit]
 
[Unit]
 
Description=Music Player Daemon
 
Description=Music Player Daemon
Line 228: Line 178:
  
 
[Install]
 
[Install]
WantedBy=default.targets
+
WantedBy=default.target
 
</nowiki>}}
 
</nowiki>}}
  
 
===Esempio con variabili===
 
===Esempio con variabili===
  
Quanto segue è una versione utente del servizio {{ic|sickbeard.service}}, che utilizza una variabile contenente il valore della home directory dell'utente che lo esegue, utilizzata da SickBeard per trovare alcuni files:
+
Esempio di avvio di {{ic|sickbeard}} come servizio utente, con definizione di una variabile utente per la directory home dove Sickbeard reperisce alcuni file di configurazione:
  
{{hc|sickbeard.service|<nowiki>
+
{{hc|~/.config/systemd/user/sickbeard.service|<nowiki>
 
[Unit]
 
[Unit]
 
Description=SickBeard Daemon
 
Description=SickBeard Daemon
Line 246: Line 196:
 
</nowiki>}}
 
</nowiki>}}
  
Come spiegato in {{ic|man systemd.unit}}, la variabile {{ic|%h}} contiene il valore della home directory dell'utente che esegue il servizio. È possibile utilizzare altre variabili, il cui elenco è disponibile nelle pagine di man di systemd.
+
Come specificato in {{ic|man systemd.unit}}, la variabile {{ic|%h}} 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 (Italiano)|systemd]].
  
===Nota per le applicazioni X11===
+
===Nota per applicazioni X11===
  
La maggior parte delle applicazioni grafiche richiedono che la variabile d'ambiente {{ic|DISPLAY}} sia impostata per essere avviate (se i propri servizi non si avviano, questa è la prima cosa da controllare). Assicurarsi quindi di includerla nei propri servizi:
+
La maggior parte delle applicazioni X11, necessitano della variabile {{ic|DISPLAY}} per essere eseguite. Vedere a tal proposito la sezione [[#DISPLAY e XAUTHORITY]].
  
{{hc|$HOME/.config/systemd/user/parcellite.service|<nowiki>
+
==Esempi d'uso==
  
 +
===Multiplexer di terminale persistente===
 +
 +
{{Out of date|References {{ic|user-session@.service}} instead of {{ic|user@.service}}; the latter does not contain {{ic|1=Conflicts=getty@tty1.service}}.}}
 +
 +
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:
 +
 +
{{bc|1=
 
[Unit]
 
[Unit]
Description=Parcellite clipboard manager
+
Description=Terminal multiplexer
 +
Documentation=info:screen man:screen(1) man:tmux(1)
 +
After=cruft.target
 +
Wants=cruft.target
 +
 
 +
[Install]
 +
Alias=default.target
 +
}}
 +
 
 +
{{ic|cruft.target}}, like {{ic|mystuff.target}} 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 {{ic|/tmp/gpg-agent-info}}. This sample session, when you start X, will also be able to run X programs, since DISPLAY is set.
 +
 
 +
{{bc|1=
 +
[Unit]
 +
Description=tmux: A terminal multiplixer
 +
Documentation=man:tmux(1)
 +
After=gpg-agent.service
 +
Wants=gpg-agent.service
  
 
[Service]
 
[Service]
ExecStart=/usr/bin/parcellite
+
Type=forking
Environment=DISPLAY=:0 # <= !
+
ExecStart=/usr/bin/tmux start
 +
ExecStop=/usr/bin/tmux kill-server
 +
Environment=DISPLAY=:0
 +
EnvironmentFile=/tmp/gpg-agent-info
  
 
[Install]
 
[Install]
WantedBy=mystuff.target
+
WantedBy=multiplexer.target
</nowiki>}}
+
}}
  
Sarebbe però preferibile non inserire direttamente il valore della variabile {{ic|DISPLAY}} nei servizi (specialmente se si hanno più schermi):
+
Once this is done, {{ic|systemctl --user enable}} {{ic|tmux.service}}, {{ic|multiplexer.target}} and any services you created to be run by {{ic|cruft.target}} and you should be set to go! Activated {{ic|user-session@.service}} as described above, but be sure to remove the {{ic|1=Conflicts=getty@tty1.service}} from {{ic|user-session@.service}}, 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!
  
{{hc|$HOME/.config/systemd/user/x-app-template@.service|<nowiki>
+
===Window manager===
  
 +
Per eseguire un window manager come servizio di systemd, sarà necessario [[#Avvio di Xorg come servizio utente|avviare Xorg come servizio utente]]. Di seguito, un esempio utilizzando awesome:
 +
 +
{{hc|~/.config/systemd/user/awesome.service|<nowiki>
 
[Unit]
 
[Unit]
Description=Your amazing and original description
+
Description=Awesome window manager
 +
After=xorg.target
 +
Requires=xorg.target
  
 
[Service]
 
[Service]
ExecStart=/full/path/to/the/app
+
ExecStart=/usr/bin/awesome
Environment=DISPLAY=%i # <= !
+
Restart=always
 
+
RestartSec=10
 +
 
[Install]
 
[Install]
WantedBy=mystuff.target
+
WantedBy=wm.target
 
</nowiki>}}
 
</nowiki>}}
  
È ora possibile avviarli con:
+
{{Nota|La sezione {{ic|[Install]}} include una direttiva {{ic|WantedBy}}. All'utilizzo di {{ic|systemctl --user enable}}, verrà creato il link {{ic|~/.config/systemd/user/wm.target.wants/''window_manager''.service}}, consentendo l'avvio al login. Si raccomanda l'abilitazione di questo servizio, e non la creazione manuale del link simbolico.}}
 
+
systemctl --user {start|enable} x-app@display-in-uso.service # <= :0 nella maggior parte dei casi
+
 
+
==Articoli correlati==
+
  
* [http://blog.gtmanfred.com/?p=26 guida originale di gtmanfred]{{Linkrot|2013|04|12}}
+
==Riferimenti==
* [https://bitbucket.org/KaiSforza/systemd-user-units/wiki/Home il wiki di KaiSforza, su BitBucket]
+
* [https://bitbucket.org/KaiSforza/systemd-user-units/wiki/Home Wiki Bitbucket di KaiSforza]
* [https://github.com/grawity/systemd-user-units Utile raccolta di units per systemd]
+
* [https://github.com/zoqaeski/systemd-user-units Servizi di Zoqaeski su GitHub]
* [https://bitbucket.org/KaiSforza/systemd-user-units Altre units utente per systemd]
+
* [https://github.com/grawity/systemd-user-units Collezione di servizi utente systemd]
 +
* [https://bbs.archlinux.org/viewtopic.php?id=167115 Discussione sul forum di Arch a seguito dei cambiamenti introdotti a partire da systemd 206]

Latest revision as of 17:05, 6 August 2016

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.
  • /etc/systemd/user/ directory per i servizi definiti dall'amministratore di sistema.
  • ~/.config/systemd/user/ directory per i servizi utente.

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

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 [1] e [2] 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 systemctl --user enable servizio per ogni servizio.

D-Bus

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

Nota: Se precedentemente si sono creati tali file manualmente nella cartella /etc/systemd/user/ o ~/.config/systemd/user/, è ora possibile rimuoverli.

Variabili d'ambiente

L'istanza utente di systemd non eredita le variabili d'ambiente definite in .bashrc 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 DefaultEnvironment in ~/.config/systemd/user.conf. Viene applicata solo alle unità utente di un utente specifico.
  2. Utilizzare l'opzione DefaultEnvironment in /etc/systemd/user.conf. Viene applicata a tutti i servizi utente.
  3. Creare un file di configurazione in /etc/systemd/system/user@.service.d/. Viene applicata a tutti i servizi utente.
  4. In qualsiasi momento, tramite i comandi systemctl --user set-environment 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.
Suggerimento: Per definire più variabili contemporaneamente, si crei un file di configurazione contentente una lista di coppie chiave=valore, separate da uno spazio, e si aggiunga xargs systemctl --user set-environment < /path/to/file.conf al file di configurazione utente della shell in uso.

Una variabile che si potrebbe voler definire è PATH.

DISPLAY e XAUTHORITY

La variabile DISPLAY viene utilizzata da qualsiasi applicazione X per individuare il display da utilizare, mentre XAUTHORITY identifica il percorso al file .Xauthority 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 /etc/X11/xinit/xinitrc.d/50-systemd-user.sh 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 .bashrc o .bash_profile, anche PATH 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 .bash_profile, dopo aver definito la variabile PATH:

~/.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
Attenzione: I servizi systemd non sono sessioni, dal momento che vengono eseguiti al di fuori di logind. Non si utilizzi la funzionalità di lingering per abilitare il login autometico, dal momento che questo renderà inutilizzabile la sessione.

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

Tango-inaccurate.pngThe factual accuracy of this article or section is disputed.Tango-inaccurate.png

Reason: Questa configurazione avvia due istanze di D-Bus: una per il desktop e l'altra per systemd. Perchè non utilizzare quella di systemd? (Discuss in Talk:Systemd/User (Italiano)#)

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

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

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 ~/.xinitrc non ritorni, quindi si inserisca wait come ultimo comando, o si aggiunga exec 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 dbus.service

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, xorg-server 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).

Nota: Si noti che quanto sopra non è una restrizione imposta da logind: Xorg necessita infatti di sapere di quale sessione appropriarsi e, ad ora, ottiene questa informazione chiamando la funzione GetSessionByPID di logind, utilizzando il proprio PID come argomento. Si vedano questo thread e i sorgenti di Xorg. È probabilmente possibile modificare Xorg in modo che ottenga la sessione dalla tty sulla quale viene avviata.

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:

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

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

~/.config/systemd/user/xorg@.socket
[Unit]
Description=Socket for xorg at display %i

[Socket]
ListenStream=/tmp/.X11-unix/X%i
~/.config/systemd/user/xorg@.service
[Unit]
Description=Xorg server at display %i

Requires=xorg@%i.socket
After=xorg@%i.socket

[Service]
Type=simple
SuccessExitStatus=0 1

ExecStart=/usr/bin/Xorg :%i -nolisten tcp -noreset -verbose 2 "vt${XDG_VTNR}"

Dove ${XDG_VTNR} è 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
Nota: Xorg dovrebbe essere lanciato dallo stesso terminale virtuale dove si è effettuato il login, altrimenti loging considererà la sessione come inattiva.

3. Assicurarsi di definire la variabile d'ambiente DISPLAY come spiegato sopra[broken link: invalid section].

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 XDG_VTNR può essere definita nell'ambiente di systemd partendo da .bash_profile, cosa che renderebbe possibile avviare qualsiasi applicazione X11, compreso un window manager, come unità utente systemd, inserendo una dipendenza a xorg@0.socket.

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 [4] e [5].

Scrivere servizi utente

Esempio

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

~/.config/systemd/user/mpd.service
[Unit]
Description=Music Player Daemon

[Service]
ExecStart=/usr/bin/mpd --no-daemon

[Install]
WantedBy=default.target

Esempio con variabili

Esempio di avvio di sickbeard 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 man systemd.unit, la variabile %h 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 DISPLAY per essere eseguite. Vedere a tal proposito la sezione #DISPLAY e XAUTHORITY.

Esempi d'uso

Multiplexer di terminale persistente

Tango-view-refresh-red.pngThis article or section is out of date.Tango-view-refresh-red.png

Reason: References user-session@.service instead of user@.service; the latter does not contain Conflicts=getty@tty1.service. (Discuss in Talk:Systemd/User (Italiano)#)

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:

[Unit]
Description=Terminal multiplexer
Documentation=info:screen man:screen(1) man:tmux(1)
After=cruft.target
Wants=cruft.target

[Install]
Alias=default.target

cruft.target, like mystuff.target 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.

[Unit]
Description=tmux: A terminal multiplixer
Documentation=man:tmux(1)
After=gpg-agent.service
Wants=gpg-agent.service

[Service]
Type=forking
ExecStart=/usr/bin/tmux start
ExecStop=/usr/bin/tmux kill-server
Environment=DISPLAY=:0
EnvironmentFile=/tmp/gpg-agent-info

[Install]
WantedBy=multiplexer.target

Once this is done, systemctl --user enable tmux.service, multiplexer.target and any services you created to be run by cruft.target and you should be set to go! Activated user-session@.service as described above, but be sure to remove the Conflicts=getty@tty1.service from user-session@.service, 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:

~/.config/systemd/user/awesome.service
[Unit]
Description=Awesome window manager
After=xorg.target
Requires=xorg.target

[Service]
ExecStart=/usr/bin/awesome
Restart=always
RestartSec=10
 
[Install]
WantedBy=wm.target
Nota: La sezione [Install] include una direttiva WantedBy. All'utilizzo di systemctl --user enable, verrà creato il link ~/.config/systemd/user/wm.target.wants/window_manager.service, consentendo l'avvio al login. Si raccomanda l'abilitazione di questo servizio, e non la creazione manuale del link simbolico.

Riferimenti