Le gestionnaire RGM appelle la méthode de Démarrage sur un noeud du cluster lorsque le groupe de ressources contenant la ressource du service de données est connecté à ce noeud ou lorsque la ressource est activée. Dans l'application échantillon, la méthode de Démarrage active le démon in.named (système de nom de domaine) sur ce noeud.
#!/bin/ksh # # Méthode de démarrage de HA-DNS. # # Cette méthode démarre le service de données sous le contrôle de la fonction PMF. # Avant de démarrer le processus in.named du service de noms de domaine, elle exécute # quelques contrôles « sanitaires ». La balise de la fonction PMF pour le service de # données est $RESOURCE_NAME.named. La fonction PMF tente de démarrer le service suivant # un nombre de fois spécifié (Nombre_nouvelles_tentatives) et si le nombre de tentatives # est supérieur à cette valeur dans l'intervalle de temps spécifié # (Intervalle_nouvelles_tentatives), la fonction PMF notifie un échec au démarrage du # service. Nombre_nouvelles_tentatives et Intervalle_nouvelles_tentatives sont des # propriétésde l'ensemble des ressources du fichier RTR. #pragma ident “@(#)dns_svc_start 1.1 00/05/24 SMI” ############################################################################### # Analysez les arguments du programme. # function parse_args # [args ...] { typeset opt while getopts `R:G:T:' opt do case “$opt” in R) # Nom de la ressource DNS. RESOURCE_NAME=$OPTARG ;; G) # Nom du groupe de ressources dans lequel la ressource est # configurée. RESOURCEGROUP_NAME=$OPTARG ;; T) # Nom du type de ressources. RESOURCETYPE_NAME=$OPTARG ;; *) logger -p ${SYSLOG_FACILITY}.err \ -t [$RESOURCETYPE_NAME,$RESOURCEGROUP_NAME,$RESOURCE_NAME] \ “ERROR: Option $OPTARG unknown” exit 1 ;; esac done } ############################################################################### # MAIN # ############################################################################## export PATH=/bin:/usr/bin:/usr/cluster/bin:/usr/sbin:/usr/proc/bin:$PATH # Obtenez la fonction syslog à utiliser pour consigner les messages. SYSLOG_FACILITY=`scha_cluster_get -O SYSLOG_FACILITY` # Analysez les arguments qui ont été transmis à cette méthode parse_args “$@” PMF_TAG=$RESOURCE_NAME.named SYSLOG_TAG=$RESOURCETYPE_NAME,$RESOURCEGROUP_NAME,$RESOURCE_NAME # Accédez à la valeur de la propriété Rép_conf de la ressource afin de démarrer le # service de noms de domaine. Entrez le nom de la ressource et le groupe de ressources, # recherchez la valeur Rép_conf définie par l'administrateur du cluster lors de l'ajout # de la ressource. config_info=`scha_resource_get -O Extension -R $RESOURCE_NAME -G $RESOURCEGROUP_NAME Confdir` # scha_resource_get retourne le type et la valeur de la propriété d'extension # Accédez uniquement à la valeur de la propriété d'extension. CONFIG_DIR=`echo $config_info # | awk `{print $2}'` # Vérifiez que $CONFIG_DIR est accessible. if [ ! -d $CONFIG_DIR ]; then logger -p ${SYSLOG_FACILITY}.err -t [$SYSLOG_TAG] \ “${ARGV0} Directory $CONFIG_DIR missing or not mounted” exit 1 fi # Configurez le répertoire $CONFIG_DIR si les fichiers de données contiennent # des noms de chemin d'accès relatifs. cd $CONFIG_DIR # Vérifiez que le répertoire $CONFIG_DIR contient bien le fichier named.conf. if [ ! -s named.conf ]; then logger -p ${SYSLOG_FACILITY}.err -t [$SYSLOG_TAG] \ “${ARGV0} File $CONFIG_DIR/named.conf is missing or empty” exit 1 fi # Accédez à la valeur de Nombre_nouvelles_tentatives à partir du fichier RTR. RETRY_CNT=`scha_resource_get -O Retry_Count -R $RESOURCE_NAME -G \ $RESOURCEGROUP_NAMÈ # Accédez à la valeur Intervalle_nouvelles_tentatives à partir du fichier RTR. # Convertissez cette valeur, à la base en secondes, en minutes pour le transfert # vers pmfadm. Veuillez noter qu'il s'agit d'une conversion avec arrondissement : # par exemple, 50 secondes devient 1 minute. ((RETRY_INTRVAL = `scha_resource_get -O Retry_Interval -R $RESOURCE_NAME -G $RESOURCEGROUP_NAMÈ / 60)) # Démarrez le démon in.named sous le contrôle de la fonction PMF. Laissez-le # s'interrompre et redémarrer jusqu'à ce que la valeur $RETRY_COUNT dans l'intervalle # $RETRY_INTERVAL soit atteinte. En cas d'autre échec, la fonction PMF cesse d'essayer # de le redémarrer. Si un processus est déjà enregistré sous la balise <$PMF_TAG>, # la fonction PMF envoie un message d'alerte indiquant que le processus est toujours # opérationnel. echo “Retry interval is “$RETRY_INTRVAL pmfadm -c $PMF_TAG.named -n $RETRY_CNT -t $RETRY_INTRVAL \ /usr/sbin/in.named -c named.conf # Consignez un message indiquant que HA-DNS a démarré. if [ $? -eq 0 ]; then logger -p ${SYSLOG_FACILITY}.info -t [$SYSLOG_TAG]\ “${ARGV0} HA-DNS successfully started” fi exit 0 |