Guide des développeurs pour les services de données Sun Cluster pour SE Solaris

Méthode Mise_à_jour

Le gestionnaire RGM appelle la méthode Mise_à_jour pour notifier à une ressource en cours d'exécution que ses propriétés ont été modifiées.


Exemple B–10 Méthode Mise_à_jour_dns

#!/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