SQWareProduction:oracle:bin:sqwora RmanClone.ksh

De WikiFr

Presentation

Script $gvsqw_OraBin/sqwora_RmanClone.ksh :


Realise un clone RMAN
Le script est totalement automatique:

  • Check space (si vous avez customise la fonction)
  • Recupere le backup choisi qui peut etre:


- LastFull => restore le dernier backup full
- LastInc => restore le dernier backup incremental
- MaxTime => restore le dernier backup
- <tag> => restore ce backup tag (partie du nom de fichier)

  • Unregister du catalogue RMAN
  • Sauvegarde des anciens password
  • Supprime l'ancienne database
  • Execute le clone


Le script peut aussi:

  • Ignore les warnings d'espace disque (par defaut, sort en erreur)
  • Realise juste la copie des backups et s'arrete
  • change de user unix target/source
  • choix du degre de parallelisme de la copie des backups
  • Envoi du rapport d'execution
  • Execute un shell script avant load
  • Execute un shell script apres load


Ce script utilise le fichier de configuration $gvsqw_RootCfg/sqwora_Rman.cfg



Aide en ligne

L'aide en ligne est accessible dans la plupart des scripts avec l'option -h.
Ex: $gvsqw_OraBin/sqwora_RmanClone.ksh -h
Contenu de l'aide :

Sourcing sqwora_Global.lib v2020.05 SQWareProduction for Oracle (dbSQWare) ... 

Utilisation: sqwora_RmanClone.ksh [-h] -I <instance> -IS <instance> -US <hostname> -T <Type> [+ options]

DESCRIPTION
   sqwora_RmanClone.ksh duplicate instance par Rman (clone)
SUPPORT
   Oracle versions supportees: 10gR2 <= v <= 19c

PARAMETERS
     -I  instance       : Target instance (clone).
     -IS instance       : Instance source.
     -US hostname       : Hostname pour l'instance source.
     -T  type           : Quel backup utiliser:
                           - LastFull => restore le dernier backup full
                           - LastInc  => restore le dernier backup incremental
                           - MaxTime  => restore le dernier backup
                           - <tag>    => restore ce backup tag (partie du nom de fichier)
OPTIONS
     -h  help           : Affichage de l'aide complete.
     -s                 : Affichage des exemples d'utilisation.
     -P  Nb processes   : Nombre de threads en parallele (par defaut 4).
     -FRT return_code   : Valeur forcee du code retour sur erreur
     -UUS  username     : Source unix user(par defaut, meme que la target).
     -Before  script    : Script a executer avant clone.
     -After   script    : Script a executer apres clone.
     -AddMail email     : Adresse Email a ajouter a 'pmexpdba@gmail.com'.
     -SendReport        : Envoi du rapport d'execution.
     -NoMail            : Desactive l'envoi de mail sur erreur a pmexpdba@gmail.com (par defaut, envoi sur erreur).
     -CopyOnly          : Realise juste la copie des backups et s'arrete.
     -IgnoreDiskWarning : Ignore les warnings d'espace disque (par defaut, sort en erreur).
     -Locale   locale   : Force la Locale d'affichage de l'aide (fr,en).
     -Exec              : Duplicate (defaut, affiche les commandes generees).

Information.png
Information:
Pour etre sur d'avoir une aide a jour, reportez vous directement a l'aide en ligne du script avec l'option -h .


Traitement de l'erreur

Erreurs de parse des arguments

Ce type de message est genere:

Lack 'instance' parameter, Utilisation: sqwora_RmanClone.ksh [-h] -I <instance> -IS <instance> -US <hostname> -T <Type> [+ options]

Si vous vous connectez via un terminal, aucun mail ne sera envoyé et vous aurez plutôt ce type de message:

Not sending mail because you are in connected mode !!!
Lack 'instance' parameter

Si vous n'êtes pas connecté à un terminal, le message d'erreur apparaît et est envoyé par mail à l'adresse contenue dans la variable $gvsqw_GlobalMail (Voir l'aide pour personnaliser cette variable). L'objet commence toujours par "$gvsqw_MailMsg_oracle : " (Voir l'aide pour personnaliser cette variable).

Information.png
Information:
L'envoi de mail peut être désactivé par l'option -NoMail pour une exécution.


Execution errors

Que vous soyez ou non connecté à un terminal, le message d'erreur apparaît et un mail contenant un résumé des erreurs de traitement est envoyé à l'adresse contenue dans la variable $gvsqw_GlobalMail (Voir l'aide pour personnaliser cette variable). L'objet commence toujours par "$gvsqw_MailMsg_oracle : " (Voir l'aide pour personnaliser cette variable).

Information.png
Information:
L'envoi de mail peut être désactivé par l'option -NoMail pour une exécution.


Exemples d'utilisation

Sourcing sqwora_Global.lib v2020.05 SQWareProduction for Oracle (dbSQWare) ... 

#Standard (Locale) help for script sqwora_RmanClone.ksh:


$gvsqw_OraBin/sqwora_RmanClone.ksh -h
#Affichage de l'aide en ligne pour ce script

$gvsqw_OraBin/sqwora_RmanClone.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -T <Type> -NoMail
#Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, send on error)

$gvsqw_OraBin/sqwora_RmanClone.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -T <Type> -Exec
#Execute les commandes generees

$gvsqw_OraBin/sqwora_RmanClone.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -T <Type>
#Genere les commandes mais ne les execute pas !

$gvsqw_OraBin/sqwora_RmanClone.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -T <Type> -FRT <NumericValue> -Exec
#Force le code retour a '<NumericValue>' sur erreur (si pas d'erreur, exit 0!)
#Vous pouvez aussi forcer le code retour de ce script pour tous
#si vous settez la variable d'environnement: $gvsqw_ForcedReturnCodeScript_sqwora_RmanClone=<NumericValue>
#dans le fichier de configuration $gvsqw_OraBin/../etc_cust/sqwora_GlobalVar.cfg

Information.png
Information:
Pour être sûr que les exemples sont exacts, reportez-vous directement à l'option d'aide en ligne du script -s .