SQWareProduction:oracle:bin:sqwora SchemaRefresh.ksh
Sommaire
Presentation
Script $gvsqw_OraBin/sqwora_SchemaRefresh.ksh :
Refresh un ou plusieurs schemas par exp/imp
Actions:
- Realise l'export du schema distant par ssh
- Rapatrie le fichier dump par scp
- Drop tous les objets du schema a rafraichir
- Realise l'import
Le script peut aussi:
- changer de user unix target/source
- envoie par email le rapport de refresh
- execute un shell script avant load
- execute un shell script apres load
Aide en ligne
L'aide en ligne est accessible dans la plupart des scripts avec l'option -h.
Ex: $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -h
Contenu de l'aide :
Sourcing sqwora_Global.lib v2024.07 SQWareProduction for Oracle (dbSQWare) ... Utilisation: sqwora_SchemaRefresh.ksh [-h] -I <instance> -IS <instance> -US <hostname> -O <owner> [+ options] DESCRIPTION sqwora_SchemaRefresh.ksh refresh schema par exp/imp SUPPORT Oracle versions supportees: 8i <= v <= 11gR2 PARAMETERS -I instance : Instance cible. -IS instance : Instance source de l'export. -US hostname : Hostname source. -O owner(s) : Schema(s) à importer. OPTIONS -h : Affichage de l'aide complete. -s : Affichage des exemples d'utilisation. -TU owner(s) : To user, schema(s) cible(s) a recharger. -FRT code : Valeur forcee du code retour sur erreur. -UUS username : Source unix user(par defaut, identique a la cible). -Before scriptname : Script a executer avant reload et avant de drop les objects. -After scriptname : Script a executer apres reload. -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 la commande (par defaut, affiche les commandes generees).
Traitement de l'erreur
Erreurs de parse des arguments
Ce type de message est genere:
Lack instance parameter, Utilisation: sqwora_SchemaRefresh.ksh [-h] -I <instance> -IS <instance> -US <hostname> -O <owner> [+ 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:01:09 End : 2020-11-29 20:01:09 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_oracle : " (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_oracle : " (Voir l'aide pour personnaliser cette variable).
Exemples d'utilisation
Sourcing sqwora_Global.lib v2024.07 SQWareProduction for Oracle (dbSQWare) ... #Standard (Locale) help for script sqwora_SchemaRefresh.ksh: $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -h #Affichage de l'aide en ligne pour ce script $gvsqw_OraBin/sqwora_SchemaRefresh.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_OraBin/sqwora_SchemaRefresh.ksh -s #Affichage des exemples d'utilisation pour ce script $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O <OwnerList> #Genere les commandes mais ne les execute pas ! $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O <OwnerList> -Exec #Refresh un ou plusieurs schemas <OwnerList> par exp/imp $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O OLDSCH -TU NEWSCH -Exec #Importe le schema OLDSCH, sur le schema cible NEWSCH $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O <OwnerList> -UUS 'dba_42' -Exec #Utilisateur unix a utiliser, ici 'dba_42' (par defaut identique a la cible) $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O <OwnerList> -Before $Home/scripts/XXX.ksh -Exec #Script a executer avant reload et avant de drop les objects $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O <OwnerList> -After $Home/scripts/XXX.ksh -Exec #Script a executer apres reload $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O <OwnerList> -AddMail 'mymail1@mydomaine.com,mymail2@mydomaine.com' -Exec #Ajoute la liste de mail a l'adresse par defaut geree par $gvsqw_GlobalMail $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O <OwnerList> -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_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O <OwnerList> -NoMail -Exec #Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, seulement en cas d'erreur) $gvsqw_OraBin/sqwora_SchemaRefresh.ksh -I $ORACLE_SID -IS <SourceInstance> -US <SourceHost> -O <OwnerList> -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_sqwora_SchemaRefresh=<NumericValue> #dans le fichier de configuration $gvsqw_OraBin/../etc_cust/sqwora_GlobalVar.cfg