SQWareProduction:mssql:bin:sqwmsq RestoreDatabase.ksh

De WikiFr_dbSQWare
Aller à : navigation, rechercher

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 (by default: '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.02 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 : Database 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 (by default: 'HKEY_LOCAL_MACHINE', 'BackupDirectory').
     -DS  DatabaseSource: Database 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).

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 '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).

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_mssql : " (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 sqwmsq_Global.lib v2024.02 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 forçage 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 (by default, send on error)

$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

Information.png
Information:
Pour être sûr que les exemples sont exacts, reportez-vous directement à l'option d'aide en ligne du script -s .