SQWareProduction:db2:bin:sqwdb2 ParallelRun.ksh

De WikiFr_dbSQWare
Révision datée du 14 avril 2019 à 18:03 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_D2db2Bin/sqwdb2_ParallelRun.ksh :


Gere l'execution de commandes unix en parallele
Prend en parametre un fichier avec les commandes a executer
Vous pouvez choisir:

  • Le degre de parallelisme
  • Aggressivite de lancement (nombre de secondes entre deux lancements)
  • Aggressivite de check de fin (nombre de secondes entre deux check de fin)




Aide en ligne

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

Sourcing sqwdb2_Global.lib v2024.07 SQWareProduction for Db2 (dbSQWare) ... 

Usage: sqwdb2_ParallelRun.ksh [-h] -f <FileName> [+ options]

DESCRIPTION
   sqwdb2_ParallelRun.ksh runs commands from <FileName> in parallel mode
SUPPORT
   All rdbms type and version

PARAMETERS
     -f  FileName       : File name containing the commands to run.
OPTIONS
     -h                 : Display the full usage.
     -s                 : Display samples of usage.
     -P  Nb threads     : Number of threads in parallel (by default 2).
     -AGR Nb_sec        : Nb of seconds between two runs (by default 10s).
     -AGE Nb_sec        : Nb of seconds between two checks of end (by default 30s).
     -FRT return_code   : Force return code value on error.
     -AddMail   email   : Email address to add at 'pmexpdba@gmail.com'.
     -SendReport        : Send execution log report.
     -NoMail            : Deactivate sendmail on error to pmexpdba@gmail.com (by default, send on error).
     -Locale    locale  : Force Locale for help display (fr,en).
     -FormatError       : Format error message in html.
     -MailFile filename : File name containing errors to send mail with an other script (disable sendmail).
     -Exec              : Execute commands (by default, display generated commands).

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:

Usage: sqwdb2_ParallelRun.ksh [-h] -f <lvsqw_FileName> [+ options]
For full help : sqwdb2_ParallelRun.ksh -h

Si vous vous connectez via un terminal, aucun mail ne sera envoyé et vous aurez plutôt ce type de message:

No send mail because you are in connected mode !!!
Lack 'FileName' parameter
./sqwdb2_ParallelRun.ksh[1112]: db2: not found [Aucun fichier ou dossier de ce type]

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_db2 : " (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_db2 : " (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 sqwdb2_Global.lib v2024.07 SQWareProduction for Db2 (dbSQWare) ... 

#Standard generic (Locale) help for script sqwdb2_ParallelRun.ksh:

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

$gvsqw_Db2/sqwgen_ParallelRun.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_Db2/sqwgen_ParallelRun.ksh -s
#Affichage des exemples d'utilisation pour ce script

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName>
#Affiche l'ensemble des commandes generees par le script sans les executer

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName> -Exec
#MGere l'execution de commandes unix (contenues dans <FileName>) en mode parallele

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName> -AGR 20 -Exec
#Reglage du temps d'attente en secondes entre deux lancements de commandes, ici 20s (par defaut 10s)

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName> -AGE 40 -Exec
#Reglage du temps d'attente en secondes entre deux check de fin, ici 40s (par defaut 30s)

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName> -P <NumericValue> -Exec
#Execute le script sqwgen_ParallelRun.ksh avec un degre de parallelisme de '<NumericValue>'
#Utilise par defaut la variable gvsqw_NbThreadXXX dans $gvsqw_Db2/../etc/sqwgen_GlobalVar.cfg
#Vous pouvez changer le defaut sur tout l'environnement si vous settez cette variable
#dans le fichier de configuration $gvsqw_Db2/../etc_cust/sqwgen_GlobalVar.cfg

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName> -FormatError -Exec
#En cas d'erreurs, le mail envoye sera au format html

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName> -MailFile <fileName> -Exec
#En cas d'erreurs n'envoi pas de mail, et ecrit les erreurs dans un fichier <fileName>, qui sera envoyer en piece jointe avec sqwgen_FailWithoutMail.ksh

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName> -AddMail 'mymail1@mydomaine.com,mymail2@mydomaine.com' -Exec
#Ajoute la liste de mail a l'adresse par defaut geree par la variable $gvsqw_GlobalMail (seulement cette fois)

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName> -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_Db2/sqwgen_ParallelRun.ksh -f <FileName> -NoMail -Exec
#Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, seulement en cas d'erreur)

$gvsqw_Db2/sqwgen_ParallelRun.ksh -f <FileName> -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_sqwgen_ParallelRun=<NumericValue>
#dans le fichier de configuration $gvsqw_Db2/../etc_cust/sqwgen_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 .