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
|