En 2002, le système rc.d de NetBSD pour l'initialisation du
système a été intégré à FreeBSD. Les utilisateurs noteront les fichiers présents dans le
répertoire /etc/rc.d. Plusieurs de ces fichiers sont destinés
aux services de base qui peuvent être contrôlés avec les options start
, stop
, et restart
. Par exemple, sshd(8) peut être
relancé avec la commande suivante:
# /etc/rc.d/sshd restart
Cette procédure est similaire pour d'autres services. Bien sûr, les services sont généralement lancés automatiquement au démarrage dès qu'ils sont spécifiés dans le fichier rc.conf(5). Par exemple, activer le “daemon” de translation d'adresses au démarrage est aussi simple que d'ajouter la ligne suivante au fichier /etc/rc.conf:
natd_enable="YES"
Si une ligne natd_enable="NO"
est déjà présente, modifiez
alors le NO
par YES
. Les
procédures rc chargeront automatiquement les autres services dépendants lors du prochain
redémarrage comme décrit ci-dessous.
Comme le système rc.d est à l'origine destiné pour
lancer/arrêter les services au démarrage/à l'arrêt du système, les options standards
start
, stop
et restart
ne seront effectives que si les variables appropriées sont
positionnées dans le fichier /etc/rc.conf. Par exemple, la
commande sshd restart ci-dessus ne fonctionnera que si sshd_enable
est fixée à YES
dans /etc/rc.conf. Pour lancer, arrêter ou redémarrer un service
indépendemment des paramétrages du fichier /etc/rc.conf, les
commandes doivent être précédées par “one”. Par exemple pour redémarrer sshd indépendemment du paramétrage du fichier /etc/rc.conf, exécutez la commande suivante:
# /etc/rc.d/sshd onerestart
Il est facile de contrôler si un service est activé dans le fichier /etc/rc.conf en exécutant la procédure rc.d appropriée avec l'option rcvar
.
Ainsi, un administrateur peut contrôler que sshd est réellement
activé dans /etc/rc.conf en exécutant:
# /etc/rc.d/sshd rcvar # sshd $sshd_enable=YES
Note : La seconde ligne (# sshd) est la sortie de la commande sshd et non pas une console root.
Pour déterminer si un service est actif, une option appelée status
est disponible. Par exemple pour vérifier que sshd a réellement été lancé:
# /etc/rc.d/sshd status sshd is running as pid 433.
Dans certains cas, il est également possible de recharger un service avec l'option
reload
. Le système tentera d'envoyer un signal à un service
individuel, le forçant à recharger ses fichiers de configuration. Dans la plupart des cas
cela signifie envoyer un signal SIGHUP au service. Le support de
cette fonctionnalité n'est pas disponible pour chaque service.
Le système rc.d n'est pas uniquement utilisée pour les services réseaux, elle participe à la majeure partie de l'initialisation du système. Prenez par exemple le fichier bgfsck. Quand cette procédure est exécutée, il affichera le message suivant:
Starting background file system checks in 60 seconds.
Donc ce fichier est utilisé pour les vérifications du système de fichiers en arrière plan, qui sont uniquement effectuées lors de l'initialisation du système.
De nombreux services système dépendent d'autres services pour fonctionner correctement. Par exemple, NIS et les autres services basés sur les RPCs peuvent échouer s'ils sont lancés après le lancement du service rpcbind (portmapper). Pour résoudre ce problème, l'information concernant les dépendances et autres méta-données est inclue dans les commentaires au début de chaque procédure de démarrage. Le programme rcorder(8) est alors utilisé pour analyser ces commentaires lors de l'initialisation du système en vue de déterminer l'ordre dans lequel les services système seront invoqués pour satisfaire les dépendances. Les mots suivants peuvent être présents en tête de chaque fichier de démarrage:
PROVIDE: indique les services que fournit ce fichier.
REQUIRE: liste les fichiers dont dépend ce service. Ce fichier sera exécuté après les services indiqués.
BEFORE: liste les services qui dépendent du service présent. Ce fichier sera exécuté avant les services indiqués.
En utilisant ce système, un administrateur peut facilement contrôler les services du système sans avoir à se battre avec les “runlevels” comme sur d'autres systèmes d'exploitation UNIX®.
Des informations supplémentaires concernant le système rc.d peuvent être trouvées dans les pages de manuel rc(8) et rc.subr(8). Si vous êtes intéressé par l'écriture de vos propres procédures rc.d ou pour l'amélioration des procédures existantes, vous trouverez cette article utile.
Précédent | Sommaire | Suivant |
Configuration de l'utilitaire cron | Niveau supérieur | Configuration des cartes réseaux |
Ce document, ainsi que d'autres peut être téléchargé sur ftp.FreeBSD.org/pub/FreeBSD/doc/.
Pour toutes questions à propos de FreeBSD, lisez la documentation avant de contacter <questions@FreeBSD.org>.
Pour les questions sur cette documentation, contactez <doc@FreeBSD.org>.