Le gestionnaire RGM appelle la méthode de Mise_à_jour pour notifier à une ressource en cours d'exécution que ses propriétés ont été modifiées.
#!/bin/ksh # # Méthode de mise à jour de HA-DNS. # # La mise à jour réelle des propriétés est réalisée par le gestionnaire RGM. Les mises # à jour affectent uniquement le système de détection des pannes. Par conséquent, cette # méthode doit redémarrer le système de détection des pannes. #pragma ident “@(#)dns_update 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. NOM_RESSOURCE=$OPTARG ;; G) # Nom du groupe de ressources dans lequel la ressource # est configurée. NOM_GROUPE_RESSOURCES=$OPTARG ;; T) # Nom du type de ressources. NOM_TYPE_RESSOURCES=$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.monitor SYSLOG_TAG=$RESOURCETYPE_NAME,$RESOURCEGROUP_NAME,$RESOURCE_NAME # Recherchez où réside la méthode de détection en obtenant la valeur de la # propriété RÉP_BASE_TR du service de données. RÉP_BASE_TR=`scha_resource_get -O RT_BASEDIR -R $RESOURCE_NAME -G $RESOURCEGROUP_NAMÈ # Lorsque la méthode de Mise_à_jour est appelée, le gestionnaire RGM met à jour # la valeur de la propriété en cours de mise à jour. Cette méthode doit vérifier # que le système de détection des pannes (sonde) fonctionne. Le cas échéant, # interrompez-le et redémarrez-le. if pmfadm -q $PMF_TAG.monitor; then # Interrompez le détecteur qui fonctionne déjà pmfadm -s $PMF_TAG.monitor TERM if [ $? -ne 0 ]; then logger -p ${SYSLOG_FACILITY}.err -t [$SYSLOG_TAG] \ “${ARGV0} Could not stop the monitor” exit 1 else # Possible d'arrêter le service de noms de domaine avec succès. # Consignez un message. logger -p ${SYSLOG_FACILITY}.info -t [$SYSLOG_TAG] \ “Monitor for HA-DNS successfully stopped” fi # Redémarrez le détecteur. pmfadm -c $PMF_TAG.monitor -n -1 -t -1 $RT_BASEDIR/dns_probe \ -R $RESOURCE_NAME -G $RESOURCEGROUP_NAME -T $RESOURCETYPE_NAME if [ $? -ne 0 ]; then logger -p ${SYSLOG_FACILITY}.err -t [$SYSLOG_TAG]\ “${ARGV0} Could not restart monitor for HA-DNS “ exit 1 else logger -p ${SYSLOG_FACILITY}.info -t [$SYSLOG_TAG]\ “Monitor for HA-DNS successfully restarted” fi fi exit 0 |