SQWareProduction:mysql:bin:sqwmys CopyDumpDatabase.ksh
Sommaire
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).
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).
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).
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