SQWareProduction:mysql:bin:sqwmys CopyDumpDatabase.ksh

De WikiFr_dbSQWare
Révision datée du 2 juillet 2021 à 15:38 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_CopyDumpDatabase.ksh :


copie des dump \$lvsqw_CopyType



Aide en ligne

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

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

Utilisation: sqwmys_CopyDumpDatabase.ksh [[-h]] -I instance -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> [[+ options]]

DESCRIPTION
   sqwmys_CopyDumpDatabase.ksh copie des dump $lvsqw_CopyType 
SUPPORT
   MySql   versions supportees: 5.0 <= v <= 8.3
   MariaDB versions supportees: 5.5 <= v <= 11.4

PARAMETERS
     -I  instance       : Instance cible.
     -DT DatabaseTarget : Base de donnees cible.
     [
     -GetInf  u@h:path  : user@host:path pour recuperer le dump source distant.
     OR
     -PutInf  u@h:path  : user@host:path pour pousser le dump sur le host distant.
     OR
     -IS instance       : Instance source.
     -US hostname       : Hostname source.
     ]
OPTIONS
     -h                 : Affichage de l'aide complete.
     -s                 : Affichage des exemples d'utilisation.
     -NoMail            : Desactive l'envoi de mail sur erreur a pmexpdba@gmail.com (par defaut, envoi sur erreur).
     -P  Nb processes   : Nombre de threads en parallele (par defaut ).
     -HI Nb             : Nombre de generations a garder, selement pour l'option get (par defaut 1).
     -DD date_dump      : Date du dump a copier (par defaut prend le dernier).
     -RD directory      : Repertoire pour trouver le fichier dump (par defaut $HOME/mys_dump/$MYSQL_SID).
     -RDS directory     : Repertoire source pour trouver le fichier dump (par defaut $HOME/mys_dump/$lvsqw_InstanceSource).
     -UUS     username  : Utilisateur unix source (par defaut, meme que la cible).
     -Before scriptname : Script a executer avant la copie.
     -After  scriptname : Script a executer apres la copie.
     -AddMail   email   : Adresse Email a ajouter a 'pmexpdba@gmail.com'.
     -SendReport        : Envoi du rapport d'execution.
     -Locale    locale  : Force la Locale d'affichage de l'aide (fr,en).
     -Exec              : Copy files $lvsqw_CopyType (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 'GetInf' or 'PutInf' or 'SourceInstance+SourceHostname' parameter, Utilisation: sqwmys_CopyDumpDatabase.ksh [[-h]] -I instance -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> [[+ 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 'GetInf' or 'PutInf' or 'SourceInstance+SourceHostname' 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_CopyDumpDatabase.ksh:

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

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.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_CopyDumpDatabase.ksh -s
#Affichage des exemples d'utilisation pour ce script

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname>
#Generate commands but don't execute them !

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -GetInf <user@host:path>
#Generate commands but don't execute them !

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -PutInf <user@host:path>
#Generate commands but don't execute them !

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> -Exec
#Copie des dump \$lvsqw_CopyType

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> -RD <DirName> -Exec
#Repertoire local pour trouver le fichier dump

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> -RDS <DirName> -Exec
#Repertoire source pour trouver le fichier dump

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> -DD <date_dump> -Exec
#Copie les dumps de date <date> (par defaut, le dernier)

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> -UUS 'dba_42'-Exec
#Utilisateur unix a utiliser, ici 'dba_42' (par defaut identique a la cible)

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -GetInf <user@host:path> -HI <NumberOfGenerations> -Exec
#Change le nombre de generations de backup a garder

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -GetInf <user@host:path> -Before <script> -Exec
#Execute le script <script> puis fait une copie de type "Copy get"

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -GetInf <user@host:path> -After $Home/scripts/XXX.ksh -Exec
#Copie de type "get" depuis <Host>:<Path> avec <user> et ensuite execute le script $Home/scripts/XXX.ksh

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> -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_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> -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_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> -NoMail -Exec
#Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, seulement en cas d'erreur)

$gvsqw_MysBin/sqwmys_CopyDumpDatabase.ksh -I $MYSQL_SID -DT <DatabaseTarget> -IS <SourceInstance> -US <SourceHostname> -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_CopyDumpDatabase=<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 .