SQWareProduction:postgres:bin:sqwpg RestoreDatabase.ksh

De WikiFr_dbSQWare
Révision datée du 27 mai 2022 à 15:39 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_PgBin/sqwpg_RestoreDatabase.ksh :




Aide en ligne

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

Sourcing sqwpg_Global.lib v2024.07 SQWareProduction for PostgreSQL (dbSQWare) ... 

Utilisation: sqwpg_RestoreDatabase.ksh [[-h]] -I instance -DT <DatabaseTarget> [[+ options]]

DESCRIPTION
   sqwpg_RestoreDatabase.ksh restore $lvsqw_CopyType 
SUPPORT
   PostgreSQL versions supportees: 9.0 <= v <= 16

PARAMETERS
     -I  instance       : Instance cible pour le restore.
     -DT DatabaseTarget : Base de donnees cible.
OPTIONS
     -h                 : Affichage de l'aide complete.
     -s                 : Affichage des exemples d'utilisation.
     -F  fichier        : Fichier Dump a restaurer (par defaut prend le dernier).
     -DS DatabaseSource : Source base de donnees (par defaut la meme que -DT).
     -DD date_dump      : Dump date a restaurer (par defaut prend la derniere).
     -RD repertoire     : Repertoire contenant le fichier dump (par defaut /pgbackup/$PG_SID).
     -Drop              : Drop base de donnees avant le chargement, drop tous les objets a la place (par defaut, Enable).
     -NoMail            : Desactive l'envoi de mail sur erreur a pmexpdba@gmail.com (par defaut, envoi sur erreur).
     -NoDrop            : Pas de drop base de donnees avant le chargement (par defaut, Enable).
     -Create            : Cree une base de donnees avant la restauration avec les caracteres definit par defaut sur l'instance (par defaut, Enable).
     -Verbose           : Ajoute l'option --echo-queries a la cmd psql pour le restore.
     -NoCreate          : Pas de create base de donnees avant le chargement, doit exister (par defaut, Enable).
     -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).
     -FRT       code    : Valeur forcee du code retour sur erreur.
     -Exec              : Restore (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 'PG_SID' parameter, Utilisation: sqwpg_RestoreDatabase.ksh [[-h]] -I instance -DT <DatabaseTarget> [[+ 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 'PG_SID' 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_postgres : " (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_postgres : " (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 sqwpg_Global.lib v2024.07 SQWareProduction for PostgreSQL (dbSQWare) ... 

#Standard (Locale) help for script sqwpg_RestoreDatabase.ksh:

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

$gvsqw_PgBin/sqwpg_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_PgBin/sqwpg_RestoreDatabase.ksh -s
#Affichage des exemples d'utilisation pour ce script

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget>
#Genere les commandes mais ne les execute pas !

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -Exec
#Execute une restauration standard de la database cible

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -Verbose Exec
#Restaure la database cible et inscrit des commentaires detailles, les heures de demarrage et d'arret dans les logs

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -NoDrop -Exec
#Ne drop pas les bases avant de restaurer (geree par defaut par $gvsqw_DropDb)

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -Drop -Create -Exec
#Drop les bases avant de restaurer, utilise la locale de l'instance $PG_SID pour toutes les commandes create (geree par defaut par $gvsqw_CreateDb)

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> Drop -NoCreate -Exec
#Drop les bases avant de restaurer, utilise la locale de pg_dump pour toutes les commandes create (geree par defaut par $gvsqw_CreateDb)

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -DS <DatabaseSource> -After <script> -Exec
#Execute le script <script> puis restaure la database (par defaut, le meme que -DT)

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -DD <date> -Before <script> -Exec
#Execute le script <script> puis restaure la database avec le backup du <date> (par defaut prend le dernier) 

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -RD <DirName> -Exec
#Restaure la database cible avec les sauvegardes contenues dans le reprtoire <DirName>

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -F <File> -Exec
#Restaure la database avec le fichier dump <File> (par defaut prend le dernier)

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -AddMail 'mymail1@mydomaine.com,mymail2@mydomaine.com' -Exec
#Ajoute la liste de mail a l'adresse par defaut geree par $gvsqw_GlobalMail

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -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_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -NoMail -Exec
#Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, seulement en cas d'erreur)

$gvsqw_PgBin/sqwpg_RestoreDatabase.ksh -I $PG_SID -DT <DatabaseTarget> -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_sqwpg_RestoreDatabase.ksh=<NumericValue>
#dans le fichier de configuration $gvsqw_PgBin/../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 .