« SQWareProduction:mysql:bin:sqwmys CopyDumpAllDatabases.ksh » : différence entre les versions
m Updated by BatchUser |
m Updated by BatchUser |
||
| Ligne 9 : | Ligne 9 : | ||
| | | | ||
<pre> | <pre> | ||
Begining : 2020-11-29 20:00:40 | |||
End : 2020-11-29 20:00:40 | |||
Duration : 00:00:00 | |||
</pre> | </pre> | ||
| | | | ||
{{SQWareProduction_sqwmys_CopyDumpAllDatabases.ksh_example}} | {{SQWareProduction_sqwmys_CopyDumpAllDatabases.ksh_example}} | ||
}} | }} | ||
Version du 29 novembre 2020 à 20:02
Presentation
Script $gvsqw_MysBin/sqwmys_CopyDumpAllDatabases.ksh :
copie des dump de toutes les databases en parallele
Aide en ligne
L'aide en ligne est accessible dans la plupart des scripts avec l'option -h.
Ex: $gvsqw_MysBin/sqwmys_CopyDumpAllDatabases.ksh -h
Contenu de l'aide :
Sourcing sqwmys_Global.lib v2025.10 SQWareProduction for MySQL (dbSQWare) ...
Utilisation: sqwmys_CopyDumpAllDatabases.ksh [-h] -I instance -IS <SourceInstance> -US <SourceHostname> [+ options]
DESCRIPTION
sqwmys_CopyDumpAllDatabases.ksh copie des dump de toutes les bases de donnees en parallele
SUPPORT
MySql versions supportees: 5.0 <= v <= 9.2
MariaDB versions supportees: 5.5 <= v <= 11.8
PARAMETERS
-I instance : Instance cible pour copy.
[
-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
-P Nb threads : Nombre de threads en parallele (par defaut 2).
-ID listdb : Liste des bases de donnees pour execution de copy (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%').
-HI Nb : Nb de generations a garder, fonctionne uniquement avec get (par defaut 1).
-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).
-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.
-Before scriptname : Script a executer avant la copie.
-After scriptname : Script a executer apres la copie.
-NoMail : Desactive l'envoi de mail sur erreur a demo-sqwarebox@dbsqware.com (par defaut, envoi sur erreur).
-AddMail email : Adresse Email a ajouter a 'demo-sqwarebox@dbsqware.com'.
-SendReport : Envoi du rapport d'execution.
-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).
Traitement de l'erreur
Erreurs de parse des arguments
Ce type de message est genere:
Lack 'MYSQL_SID' parameter, Utilisation: sqwmys_CopyDumpAllDatabases.ksh [-h] -I instance -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:
Begining : 2020-11-29 20:00:40 End : 2020-11-29 20:00:40 Duration : 00:00:00
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 v2025.10 SQWareProduction for MySQL (dbSQWare) ... #Standard (Locale) help for script sqwmys_CopyDumpAllDatabases.ksh: $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -h #Affichage de l'aide en ligne pour ce script $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.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_CopyAllDumpDatabases.ksh -s #Affichage des exemples d'utilisation pour ce script $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -IS <SourceInstance> -US <SourceHostname> #Genere les commandes mais ne les execute pas ! $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> #Genere les commandes mais ne les execute pas ! $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -PutInf <user@host:path> #Genere les commandes mais ne les execute pas ! $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -IS <SourceInstance> -US <SourceHostname> -Exec #Execute sqwmys_CopyDumpDatabase.ksh en mode parallele pour toutes les bases de l'instance $MYSQL_SID $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> -Exec #Execute sqwmys_CopyDumpDatabase.ksh en mode parallele pour recuperer les fichiers dump de toutes les bases de l'instance $MYSQL_SID $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -PutInf <user@host:path> -Exec #Execute sqwmys_CopyDumpDatabase.ksh en mode parallele pour pousser les fichiers dump de toutes les bases de l'instance $MYSQL_SID $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -IS <SourceInstance> -US <SourceHostname> -AGR 20 -Exec #Reglage du temps d'attente en secondes entre deux lancements de commandes, 20s ici $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -IS <SourceInstance> -US <SourceHostname> -AGE 30 -Exec #Reglage du temps d'attente en secondes entre deux check de fin, 30s ici $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -IS <SourceInstance> -US <SourceHostname> -RD <DirName> -Exec #Repertoire local pour trouver le fichier dump $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -IS <SourceInstance> -US <SourceHostname> -RDS <DirName> -Exec #Repertoire source pour trouver le fichier dump $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> -ID 'DbName1,DbName2' -Exec #Execute les commandes generees pour seulement les 2 bases de donnees specifiees $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> -ED 'DbName3,DbName4' -Exec #Execute les commandes generees sauf pour les 2 bases de donnees specifiees $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> -IL '%_PROD' -Exec #Clause like pour generee une liste dynamique de bases a inclure (exemple: 'dbprod%') $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> -EL '%_TESTS' -Exec #Clause like pour generee une liste dynamique de bases a exclure (exemple: 'dbtest%') $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> -WCD '<condition>' -Exec #Clause where pour generee une liste dynamique de bases a inclure $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -IS <SourceInstance> -US <SourceHostname> -UUS 'dba_42'-Exec #Utilisateur unix a utiliser, ici 'dba_42' (par defaut identique a la cible) $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> -HI <NumberOfGenerations> -Exec #Change le nombre de generations de backup a garder $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -P <NumericValue> -Exec #Execute le script sqwmys_CopyDumpDatabase.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_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> -Before <script> -Exec #Execute le script <script> puis lance la copie dans le sens "Get" $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -GetInf <user@host:path> -After $Home/scripts/XXX.ksh -Exec #Lance la copie dans le sens "Get", puis execute le script $Home/scripts/XXX.ksh $gvsqw_MysBin/sqwmys_CopyAllDumpDatabases.ksh -I $MYSQL_SID -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_CopyAllDumpDatabases.ksh -I $MYSQL_SID -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_CopyAllDumpDatabases.ksh -I $MYSQL_SID -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_CopyAllDumpDatabases.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_CopyAllDumpDatabases=<NumericValue> #dans le fichier de configuration $gvsqw_MysBin/../etc_cust/sqwmys_GlobalVar.cfg
