[successivo] [precedente] [inizio] [fine] [indice generale] [indice ridotto] [translators] [docinfo] [indice analitico] [volume] [parte]
Quando un sistema Unix viene avviato, il kernel si prende cura di avviare il processo iniziale, Init, a partire dal quale vengono poi generati tutti gli altri. Di solito si utilizza un meccanismo di inizializzazione derivato dallo UNIX System V.
Init determina quali siano i processi da avviare successivamente, in base al contenuto di /etc/inittab
il quale a sua volta fa riferimento a una serie di script contenuti normalmente all'interno della directory /etc/rc.d/
, /etc/init.d/
, o in un'altra analoga.
All'interno di /etc/inittab
si distinguono azioni diverse in funzione del livello di esecuzione (run level), di solito un numero da zero a sei. Per convenzione, il livello zero identifica le azioni necessarie per fermare l'attività del sistema, in modo da permetterne lo spegnimento; il livello sei riavvia il sistema; il livello uno mette il sistema in condizione di funzionare in modalità monoutente.
Init è il processo principale che genera tutti gli altri. All'avvio del sistema legge il file /etc/inittab
il quale contiene le informazioni per attivare gli altri processi necessari, compresa la gestione dei terminali. Per prima cosa viene determinato il livello di esecuzione iniziale, ottenendo l'informazione dalla direttiva initdefault di /etc/inittab
. Quindi vengono attivati i processi essenziali al funzionamento del sistema e infine i processi che combaciano con il livello di esecuzione attivato.
L'eseguibile init può essere invocato dall'utente root durante il funzionamento del sistema, per cambiare il livello di esecuzione, oppure per ottenere il riesame del suo file di configurazione (/etc/inittab
):
init [opzioni] |
Segue la descrizione di alcuni esempi.
#
init 1
[Invio]
#
init 0
[Invio]
Pone il sistema al livello di esecuzione zero: arresto del sistema. Equivale (in linea di massima) all'esecuzione di shutdown -h now.
#
init 6
[Invio]
Pone il sistema al livello di esecuzione sei: riavvio. Equivale (in linea di massima) all'esecuzione di shutdown -r now.
Il file inittab
descrive quali processi vengono avviati al momento dell'avvio del sistema e durante il funzionamento normale di questo. Init, il processo principale, distingue diversi livelli di esecuzione, per ognuno dei quali può essere stabilito un gruppo diverso di processi da avviare.
La struttura dei record che compongono le direttive di questo file può essere schematizzata nel modo seguente:
id:livelli_di_esecuzione:azione:processo |
I campi vanno interpretati così:
id è una sequenza unica di due caratteri che identifica il record (la riga) all'interno di inittab;
livelli_di_esecuzione elenca i livelli di esecuzione con cui l'azione indicata deve essere eseguita;
azione indica l'azione da eseguire;
processo specifica il processo da eseguire.
Se il nome del processo inizia con un simbolo +, Init non esegue l'aggiornamento di /var/run/utmp
e /var/log/wtmp
per quel processo; ciò è utile quando il processo stesso provvede da solo a questa operazione (la descrizione del significato e dell'importanza di questi due file si trova nel capitolo 95).
Il penultimo campo dei record di questo file, identifica l'azione da compiere. Questa viene rappresentata attraverso una parola chiave, come descritto dall'elenco seguente.
|
Il secondo campo, quello dei livelli di esecuzione, può contenere diversi caratteri che stanno a indicare diversi livelli di esecuzione possibili. Per esempio, la stringa 123 indica che il processo specificato va eseguito indifferentemente per tutti i livelli di esecuzione da uno a tre. Questo campo può contenere anche una lettera dell'alfabeto: a, b o c che sta a indicare un livello a richiesta. Nel caso di azioni del tipo sysinit, boot e bootwait, il campo del livello di esecuzione viene ignorato.
Negli esempi seguenti, si mostra prima un record del file /etc/inittab
e quindi, sotto, la sua descrizione.
|
|
Inizializzazione del sistema: è la prima cosa a essere eseguita dopo l'avvio del sistema stesso. In pratica viene avviato lo script /etc/rc.d/rc.sysinit
(Red Hat).
|
Indica di eseguire /etc/rc.d/rc
, con l'argomento 1, nel caso in cui il livello di esecuzione sia pari a uno: singolo utente (Red Hat)
|
Indica lo script (/etc/rc.d/rc.M
) da eseguire per i livelli di esecuzione da due a cinque (Slackware).
|
Indica il programma da eseguire in caso di pressione della combinazione [Ctrl Alt Canc]. Il livello di esecuzione non viene indicato perché è indifferente (Slackware).
|
Indica di eseguire /etc/rc.d/rc
, con l'argomento 0, nel caso in cui il livello di esecuzione sia pari a zero: arresto del sistema (Red Hat).
|
Indica di eseguire /etc/rc.d/rc
, con l'argomento 6, nel caso in cui il livello di esecuzione sia pari a sei: riavvio (Red Hat).
|
Indica il programma da eseguire quando si verifica un problema con l'alimentazione elettrica (una vecchia edizione Slackware).
|
Come nell'esempio precedente, ma realizzato in modo differente (Slackware).
|
Indica il programma da eseguire se l'alimentazione elettrica torna normale prima del completamento del processo avviato quando si è verificato il problema (una vecchia edizione Slackware).
|
Come nell'esempio precedente, ma realizzato in modo differente (Slackware).
|
Si tratta dell'elenco di console virtuali utilizzabili. La prima si attiva per tutti i livelli di esecuzione da uno a cinque, le altre solo per i livelli superiori a uno. In questo caso è mingetty a essere responsabile dell'attivazione delle console virtuali (Red Hat).
|
Indica l'attivazione di un terminale connesso sulla prima porta seriale. Si attiva solo con i livelli di esecuzione quattro o cinque (Slackware).
|
Indica l'attivazione di un terminale remoto connesso via modem sulla seconda porta seriale. Si attiva solo con i livelli di esecuzione quattro o cinque (Slackware).
|
Nel caso il livello di esecuzione sia pari a cinque, esegue /usr/bin/X11/xdm
che si occupa di avviare una procedura di accesso (login) all'interno dell'ambiente grafico X (Red Hat).
Quando lo script di shell /etc/initscript
esiste, viene utilizzato da Init per avviare i processi indicati all'interno del file /etc/inittab
.
/etc/initscript id livello_di_esecuzione azione processo |
Di solito questo script non è presente, tuttavia potrebbe essere utile per definire delle variabili di ambiente e altre impostazioni che riguardano l'interpretazione degli script della procedura di inizializzazione del sistema. La documentazione initscript(5) mostra un esempio simile a quello seguente, che dovrebbe chiarire il senso di questa possibilità.
|
Come si vede anche dai commenti dell'esempio, initscript riceve da Init una serie di argomenti che rappresentano tutti i campi contenuti nel record corrispondente di /etc/inittab
.
La prima differenza importante che distingue le varie distribuzioni GNU sta nell'organizzazione degli script della procedura di inizializzazione del sistema. Il punto di riferimento comune è Init con il suo /etc/inittab
; da questo file si intende quali siano il comandi avviati in presenza di un livello di esecuzione determinato; quello che c'è dopo costituisce il problema più grosso.
Volendo semplificare molto le cose, si può pensare al fatto che ci dovrebbe essere una directory specifica, contenente un gruppetto di script utilizzato esclusivamente per questi scopi.
La directory in questione non ha una collocazione standard, salvo il fatto che storicamente si trova nell'ambito della gerarchia /etc/
. Le motivazioni che spingono a un'impostazione differente di questi script della procedura di inizializzazione del sistema, possono essere varie. Anche la collocazione di tale directory è controversa, a cominciare dal fatto che la directory /etc/
non dovrebbe contenere programmi e nemmeno script. Infatti, a questo proposito, la distribuzione SuSE colloca questi script nella directory /sbin/init.d/
.
Gli script della procedura di inizializzazione del sistema hanno il compito di avviare il sistema operativo e di fermarlo, attivando e disattivando tutti i servizi necessari, cioè intervenendo nell'avvio e nella conclusione del funzionamento dei demoni relativi.
Si può intuire che non sia possibile realizzare uno o più script del genere per avviare tutti i tipi di demone che possono essere presenti nel proprio sistema, anche perché ci possono essere dei servizi installati che però non si vogliono gestire. Di conseguenza, nella situazione più banale, quando si intende installare e gestire un nuovo servizio, occorre anche modificare la procedura di inizializzazione del sistema per attivare il demone relativo e per disattivarlo nel momento dell'arresto del sistema. Una cosa del genere può andare bene per una persona esperta, ma si tratta sempre di un'impostazione piuttosto scomoda.
Nel tempo si è diffuso uno standard per risolvere questo problema, ed è ciò che viene descritto nelle sezioni seguenti.
Secondo una convenzione diffusa, per facilitare l'avvio e la conclusione dei servizi si definisce una directory specifica, che potrebbe essere /etc/rc.d/init.d/
, o /etc/init.d/
, o ancora /sbin/init.d/
, all'interno della quale si possono inserire degli script che hanno una sintassi uniforme.
nome_servizio {start|stop} |
In pratica, il nome dello script tende a corrispondere a quello del servizio che si intende controllare; l'argomento costituito dalla parola chiave start fa sì che lo script avvii il servizio, mentre la parola chiave stop serve a concluderlo.
Questi script possono essere più o meno raffinati, per esempio possono accettare anche altri tipi di ordini (come restart, allo scopo di riavviare un servizio), ma la cosa più importante è che dovrebbero evitare di avviare dei doppioni, controllando prima di avviare qualcosa, se per caso questo risulta già attivo. Naturalmente, un servizio può essere ottenuto con l'avvio di diversi programmi demone e in questo è molto comodo tale sistema di script specifici.
A titolo di esempio viene mostrato come potrebbe essere composto uno script del genere, per l'avvio del servizio ipotetico denominato pippo, che si avvale del programma omonimo per gestirlo. Per semplicità, non vengono indicati accorgimenti particolari per controllare che il servizio sia già attivo o meno.
|
Lo scopo e la vera utilità di questi script sta nel facilitare una standardizzazione della procedura di inizializzazione del sistema; tuttavia si può intuire la possibilità di sfruttarli anche per attivare e disattivare manualmente un servizio, senza intervenire direttamente sui programmi relativi.
Procedendo intuitivamente, si potrebbe pensare di fare in modo che la procedura di inizializzazione del sistema, provveda a eseguire tutti gli script di controllo dei servizi, utilizzando l'argomento start all'avvio e l'argomento stop allo spegnimento. Una cosa del genere è molto semplice da realizzare, ma si pongono due problemi: alcuni servizi potrebbero essere a disposizione, senza che la procedura di inizializzazione del sistema debba avviarli automaticamente; inoltre la sequenza di attivazione e di disattivazione dei servizi potrebbe essere importante.
In pratica, si utilizza un meccanismo molto semplice: si predispongono tante directory quanti sono i livelli di esecuzione gestiti attraverso il file /etc/inittab
. Queste directory hanno il nome rcn.d/
, dove n rappresenta il numero del livello di esecuzione corrispondente. La loro collocazione effettiva potrebbe essere /etc/rcn.d/
, /etc/rc.d/rcn.d/
o anche /sbin/init.d/rcn.d/
. All'interno di queste directory si inseriscono dei collegamenti simbolici che puntano agli script descritti nella sezione precedente, in modo che siano presenti i riferimenti ai servizi desiderati per ogni livello di esecuzione (distinto in base alla directory rcn.d/
particolare).
I nomi di questi collegamenti iniziano in modo speciale: Knn
e Snn
. I collegamenti che iniziano con la lettera «S» (Start) servono per individuare gli script da utilizzare per l'attivazione dei servizi, vengono avviati con l'argomento start, in ordine alfabetico, in base alla sequenza fissata con le due cifre numeriche successive che servono proprio a distinguerne la sequenza. I collegamenti che iniziano con la lettera «K» (Kill) servono per individuare gli script da utilizzare per la disattivazione dei servizi, vengono avviati con l'argomento stop, anche questi in ordine alfabetico.
Ecco, a titolo di esempio, cosa potrebbe contenere una di queste directory:
$
tree rc6.d
[Invio]
rc6.d/ |-- K11cron -> ../init.d/cron |-- K14ppp -> ../init.d/ppp |-- K15fetchmail -> ../init.d/fetchmail |-- K19aumix -> ../init.d/aumix |-- K19setserial -> ../init.d/setserial |-- K20boa -> ../init.d/boa |-- K20exim -> ../init.d/exim |-- K20gpm -> ../init.d/gpm |-- K20inetd -> ../init.d/inetd |-- K20lprng -> ../init.d/lprng |-- K20makedev -> ../init.d/makedev |-- K20pcmcia -> ../init.d/pcmcia |-- K20postgresql -> ../init.d/postgresql |-- K20psad -> ../init.d/psad |-- K20ssh -> ../init.d/ssh |-- K25hwclock.sh -> ../init.d/hwclock.sh |-- K30etc-setserial -> ../init.d/etc-setserial |-- K79nfs-common -> ../init.d/nfs-common |-- K80nfs-kernel-server -> ../init.d/nfs-kernel-server |-- K85bind9 -> ../init.d/bind9 |-- K89atd -> ../init.d/atd |-- K89hotplug -> ../init.d/hotplug |-- K89klogd -> ../init.d/klogd |-- K90sysklogd -> ../init.d/sysklogd |-- S10portmap -> ../init.d/portmap |-- S19devfsd -> ../init.d/devfsd |-- S20sendsigs -> ../init.d/sendsigs |-- S30urandom -> ../init.d/urandom |-- S31umountnfs.sh -> ../init.d/umountnfs.sh |-- S35networking -> ../init.d/networking |-- S40umountfs -> ../init.d/umountfs |-- S50raid2 -> ../init.d/raid2 `-- S90reboot -> ../init.d/reboot 0 directories, 37 files |
A titolo di esempio viene mostrato un pezzo di uno script, per una shell Bourne o derivata, fatto per scandire un elenco di collegamenti del genere, allo scopo di attivare e di disattivare i servizi, a partire dai collegamenti contenuti nella directory /etc/rc3.d/
. Per un lettore inesperto, questo potrebbe essere un po' difficile da leggere, ma l'esempio viene aggiunto per completare l'argomento.
|
In pratica, prima si disattivano i servizi corrispondenti ai collegamenti che iniziano con la lettera «K», quindi si attivano quelli che hanno la lettera «S». Si può intuire che le directory rc0.d/
e rc6.d/
contengano prevalentemente, o esclusivamente, riferimenti che iniziano con la lettera «K», dal momento che i livelli di esecuzione corrispondenti portano all'arresto del sistema o al suo riavvio.
Appunti di informatica libera 2006.07.01 --- Copyright © 2000-2006 Daniele Giacomini -- <daniele (ad) swlibero·org>
Dovrebbe essere possibile fare riferimento a questa pagina anche con il nome procedura_di_inizializzazione_del_sistema_system_nbsp_v.htm
[successivo] [precedente] [inizio] [fine] [indice generale] [indice ridotto] [translators] [docinfo] [indice analitico]