SQWareProduction:mysql:bin:sqwmys RestoreAllDatabases.ksh

De WikiFr_dbSQWare
Révision datée du 14 avril 2019 à 18:03 par BatchUser (discussion | contributions) (Updated by BatchUser)
(diff) ← Version précédente | Voir la version actuelle (diff) | Version suivante → (diff)
Aller à : navigation, rechercher

Presentation

Script $gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh :


restauration de toutes les bases en parallele



Aide en ligne

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

Sourcing sqwmys_Global.lib v2024.07 SQWareProduction for MySQL (dbSQWare) ... 

Utilisation: sqwmys_RestoreAllDatabases.ksh [-h] -I instance [+ options]

DESCRIPTION
   sqwmys_RestoreAllDatabases.ksh restore de toutes les bases de donnees en parallele
SUPPORT
   MySql   versions supportees: 5.0 <= v <= 8.3
   MariaDB versions supportees: 5.5 <= v <= 11.4

PARAMETERS
     -I  instance       : Instance cible pour le restore.
OPTIONS
     -P  Nb threads     : Nombre de threads en parallele (par defaut 2).
     -ID   listdb       : Liste des bases de donnees pour execution de restore (par defaut toutes).
     -ED   listdb       : Liste des bases de donnees a exclure.
     -IL   likeclause   : Clause d'inclusion de type like pour generer la liste des bases de donnees (exemple: 'db%').
     -EL   likeclause   : Clause d'exclusion des bases de donnees de type like (exemple: 'nodb%').
     -RD   directory    : Repertoire contenant le fichier dump (par defaut $HOME/mys_dump/$MYSQL_SID).
     -WCD  whereclause  : Clause where pour generer la liste des databases.
     -AGR Nb_sec        : Nombre de secondes entre deux lancements (par defaut 1s).
     -AGE Nb_sec        : Nombre de secondes entre deux check de fin (par defaut 10s).
     -FRT       code    : Valeur forcee du code retour sur erreur.
     -Drop              : Drop la base de donnees avant le chargement (par defaut, Enable).
     -NoMail            : Desactive l'envoi de mail sur erreur a pmexpdba@gmail.com (par defaut, envoi sur erreur).
     -NoDrop            : Pas de drop de base de donnees avant le chargement (par defaut, Enable).
     -Create            : Create sur la base de donnees avant le chargement (par defaut, Enable).
     -Verbose           : Ajoute l'option -vv a la cmd mysql pour le restore.
     -NoCreate          : Pas de create base de donnees avant le chargement (par defaut, Enable).
     -AddMail   email   : Adresse Email a ajouter a 'pmexpdba@gmail.com'.
     -SendReport        : Envoi du rapport d'execution.
     -OptionsMySQL      : Options supplementaires lors la commande mysql (par defaut, ).
     -OptionsBeforeMySQL: Options supplementaires avant la commande mysql (par defaut, ).
     -h                 : Affichage de l'aide complete.
     -s                 : Affichage des exemples d'utilisation.
     -Locale    locale  : Force la Locale d'affichage de l'aide (fr,en).
     -Exec              : Execute les commandes generees (par 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 'MYSQL_SID' parameter, Utilisation: sqwmys_RestoreAllDatabases.ksh [-h]  -I instance [+ options]

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

No send mail because you are in connected mode !!!
Lack 'MYSQL_SID' 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_mysql : " (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_mysql : " (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 sqwmys_Global.lib v2024.07 SQWareProduction for MySQL (dbSQWare) ... 

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

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

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -Locale fr -h
#Affichage de l'aide en ligne pour ce script avec forcage de la locale 'fr' (Locale par defaut geree par $gvsqw_Locale)

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -s
#Affichage des exemples d'utilisation pour ce script

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID
#Genere les commandes mais ne les execute pas !

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -Exec
#Restauration de toutes les bases de l'isntance $MYSQL_SID en parallele

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -RD <DirName> -Exec
#Repertoire contenant les fichiers de sauvegarde

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -NoDrop -Exec
#Ne drop pas les bases avant de restaurer (geree par defaut par $gvsqw_DropDb)

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -Drop -Create -Exec
#Drop les bases avant de restaurer, utilise la locale de l'instance $MYSQL_SID pour toutes les commandes create (geree par defaut par $gvsqw_CreateDb)

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -Drop -NoCreate -Exec
#Drop les bases avant de restaurer, utilise la locale de mysqldump pour toutes les commandes create (geree par defaut par $gvsqw_CreateDb)

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -AGR 20 -Exec
#Reglage du temps d'attente en secondes entre deux lancements de commandes, 20s ici

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -AGE 30 -Exec
#Reglage du temps d'attente en secondes entre deux check de fin, 30s ici

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -ID 'DbName1,DbName2' -Exec
#Execute les commandes generees pour seulement les 2 bases de donnees specifiees

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -ED 'DbName3,DbName4' -Exec
#Execute les commandes generees sauf pour les 2 bases de donnees specifiees

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -IL '%_PROD' -Exec
#Clause like pour generee une liste dynamique de bases a inclure (exemple: 'dbprod%')

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -EL '%_TESTS' -Exec
#Clause like pour generee une liste dynamique de bases a exclure (exemple: 'dbtest%')

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -WCD '<condition>' -Exec
#Clause where pour generee une liste dynamique de bases a inclure (exemple: 'OPEN_MODE=MOUNTED')

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -P <NumericValue> -Exec
#Execute le script sqwmys_RestoreDatabase.ksh avec un degre de parallelisme de '<NumericValue>'
#Utilise par defaut la variable gvsqw_NbThreadXXX dans $gvsqw_MysBin/../etc/sqwmys_GlobalVar.cfg
#Vous pouvez changer le defaut sur tout l'environnement si vous settez cette variable
#dans le fichier de configuration $gvsqw_MysBin/../etc_cust/sqwmys_GlobalVar.cfg

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -OptionsMySQL <option> -Exec
#Option(s) additionnelle(s) pendant la commande mysql

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID OptionsBeforeMySQL <option> -Exec
#Option(s) additionnelle(s) avant la commande mysql

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -Verbose -Exec
#Ajoute l'option -vv a la command mysql lors de la restauration

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -AddMail 'mymail1@mydomaine.com,mymail2@mydomaine.com' -Exec
#Ajoute la liste de mail a l'adresse par defaut geree par $gvsqw_GlobalMail

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -SendReport -Exec
#Envoie la log par mail a la fin du traitement meme s'il n'y a pas d'erreur (par defaut, seulement en cas d'erreur)

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -NoMail -Exec
#Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, envoi sur erreur)

$gvsqw_MysBin/sqwmys_RestoreAllDatabases.ksh -I $MYSQL_SID -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_sqwmys_RestoreAllDatabases=<NumericValue>
#dans le fichier de configuration $gvsqw_MysBin/../etc_cust/sqwmys_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 .