SQWareProduction:mssql:bin:sqwmsq RestoreDatabase.ksh
Sommaire
Presentation
Script $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh :
restauration Standard de la database MsSql
script recherche dynamiquement les fichiers de backup a restaurer
et faire la synchronisation de users/logins
Le script peut aussi:
- choisir le fichier de backup
- change Path pour trouver les backup a restaurer (par defaut: 'HKEY_LOCAL_MACHINE', 'BackupDirectory')
- demarrer un script shell avant la restauration
- demarrer un script shell apres la restauration
Aide en ligne
L'aide en ligne est accessible dans la plupart des scripts avec l'option -h.
Ex: $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -h
Contenu de l'aide :
Sourcing sqwmsq_Global.lib v2024.07 SQWareProduction for MsSql (dbSQWare) ... Utilisation: sqwmsq_RestoreDatabase.ksh [-h] -I <FreeTdsAlias> -DT <DatabaseName> [+ options] DESCRIPTION sqwmsq_RestoreDatabase.ksh restore database SUPPORT MsSql versions supportees: 2000 <= v <= 2022 PARAMETERS -I Instance : Instance cible (freeTds alias). -DT TargetDatabase : Base de donnees cible a charger. OPTIONS -h : Affichage de l'aide complete. -s : Affichage des exemples d'utilisation. -F filename : Fichier de sauvegardes a charger (par defaut take the latest). -BP path : Chemin pour trouver la sauvegarde a charger (par defaut: 'HKEY_LOCAL_MACHINE', 'BackupDirectory'). -DS DatabaseSource: Base de donnees source (par defaut, la meme que -DT). -DD date : Date du dump a restaurer (par defaut prend le dernier). -FRT return_code : Valeur forcee du code retour sur erreur. -REP : Inserer dans le fichier de repetition en cas d'erreur. -Move : Generer une instruction de deplacement. -Type type : Type de restauration full,diff (par defaut full). -Before script : Script a executer avant la restauration. -After script : Script a executer apres la restauration. -BeforeSql script : Sql script a executer avant la restauration. -AfterSql script : Sql script a executer apres la restauration. -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). -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 'FreeTdsAlias' parameter, Utilisation: sqwmsq_RestoreDatabase.ksh [-h] -I <FreeTdsAlias> -DT <DatabaseName> [+ 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 'FreeTdsAlias' 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_mssql : " (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_mssql : " (Voir l'aide pour personnaliser cette variable).
Exemples d'utilisation
Sourcing sqwmsq_Global.lib v2024.07 SQWareProduction for MsSql (dbSQWare) ... #Standard (Locale) help for script sqwmsq_RestoreDatabase.ksh: $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -h #Affichage de l'aide en ligne pour ce script $gvsqw_MsqBin/sqwmsq_RestoreDatabase.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_MsqBin/sqwmsq_RestoreDatabase.ksh -s #Affichage des exemples d'utilisation pour ce script $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> #Genere les commandes mais ne les execute pas ! $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -Exec #Execute une restauration standard de la database cible $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -DS <DatabaseSource> -After <script> -Exec #Execute le script <script> puis restaure la database (par defaut, le meme que -DT) $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -DD <date> -Before <script> -Exec #Execute le script <script> puis restaure la database avec le backup du <date> (par defaut prend le dernier) $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -BP <path> -Exec #Chemin <path> des backups a restaurer (par defaut: 'HKEY_LOCAL_MACHINE', 'BackupDirectory') $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -REP -Exec #Retente les sauvegardes qui ont echoue (prend la main sur les autres options) $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -Move -Exec #Restaure les databases en deplacant l'emplacement des fichiers $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -AfterSql <script> -Exec #Execute un script sql une fois la restauration terminee $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -BeforeSql <script> -Exec #Execute un script sql avant la restauration $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -AddMail 'mymail1@mydomaine.com,mymail2@mydomaine.com' -Exec #Ajoute la liste de mail a l'adresse par defaut geree par $gvsqw_GlobalMail $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -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_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -Type <TypeRestore> -Exec #Change le type de backup (full,diff) $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -NoMail -Exec #Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, seulement en cas d'erreur) $gvsqw_MsqBin/sqwmsq_RestoreDatabase.ksh -I $Alias -DT <DbName> -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_sqwmsq_RestoreDatabase=<NumericValue> #dans le fichier de configuration $gvsqw_MsqBin/../etc_cust/sqwmsq_GlobalVar.cfg