« SQWareProduction:sybase:bin:sqwsyb UpdtStatsAllDatabases.ksh » : différence entre les versions
m Updated by BatchUser |
m Updated by BatchUser |
| (2 versions intermédiaires par le même utilisateur non affichées) | |
(Aucune différence)
| |
Dernière version du 2 juillet 2021 à 15:38
Presentation
Script $gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh :
Execution de sqwsyb_UpdtStatsDatabase.ksh en mode parallele
Vous pouvez choisir:
*NoHashing
- Aggressivite de lancement (nombre de secondes entre deux lancements)
- Aggressivite de check de fin (nombre de secondes entre deux check de fin)
Filtres de generation de la liste des databases (vous pouvez tous les mixer):
- Liste d'inclusion de database
- Liste d'exclusion de database
- Clause d'inclusion de type like
- Clause d'exclusion de type like
- Clause where
Aide en ligne
L'aide en ligne est accessible dans la plupart des scripts avec l'option -h.
Ex: $gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -h
Contenu de l'aide :
Sourcing sqwsyb_Global.lib v2025.10 SQWareProduction for Sybase (dbSQWare) ...
Utilisation: sqwsyb_UpdtStatsAllDatabases.ksh [-h] -I <dataserver> [+ options]
DESCRIPTION
sqwsyb_UpdtStatsAllDatabases.ksh update statistics de toutes les bases de donnees en parallele
SUPPORT
Sybase versions supportees: 15 <= v <= 16.0
PARAMETERS
-I dataserver : Dataserver cible.
OPTIONS
-P Nb threads : Nombre de threads en parallele (par defaut 2).
-ID listdb : Liste des bases de donnees pour execution de update statistics (par defaut toutes).
-ED listdb : Liste des bases de donnees a exclure.
-IL liceclause : Clause d'inclusion de type like pour generer la liste des bases de donnees (exemple: 'db%').
-EL likeclause : Clause d'exclusion des bases de donnees de type like (exemple: 'nodb%').
-WCD whereclause : Clause where pour generer la liste des databases.
-FRT code : Valeur forcee du code retour sur erreur.
-Del : Supprime les stats avant calculs.
-Dist : Pour connexion distante a la base de donnees (change $gvsqw_DbaUser to $gvsqw_DistDbaUser ).
-AddMail email : Adresse Email a ajouter a 'demo-sqwarebox@dbsqware.com'.
-SendReport : Envoi du rapport d'execution.
-AGR Nb_sec : Nombre de secondes entre deux lancements (par defaut 10s).
-AGE Nb_sec : Nombre de secondes entre deux check de fin (par defaut 30s).
-Type type : Type de statistics 'default','index','table','all' (par defaut index).
-NoMail : Desactive l'envoi de mail sur erreur a demo-sqwarebox@dbsqware.com (par defaut, envoi sur erreur).
-SizeMaxTable Size : Prend en compte les tables <= $lvsqw_SizeMaxTable Mo (par defaut, 1000000 Mo).
-MinPctChange pct : Changement minimum des tables en pourcentage pour les prendre en compte (par defaut, datachange>=).
-Hashing : Active le hachage (quand le rowcount >= 1000000) quand ASE version >= 15.7 ESD#2 ou SP50 (par defaut, False).
-NoHashing : Desactive le hachage.
-HashSize Size : Rowcount minimum pour le hachage (par defaut, 1000000).
-h : Affichage de l'aide complete.
-s : Affichage des exemples d'utilisation.
-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 'dataserver' parameter, Utilisation: sqwsyb_UpdtStatsAllDatabases.ksh [-h] -I <dataserver> [+ 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 'dataserver' 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_sybase : " (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_sybase : " (Voir l'aide pour personnaliser cette variable).
Exemples d'utilisation
Sourcing sqwsyb_Global.lib v2025.10 SQWareProduction for Sybase (dbSQWare) ...
#Standard (Locale) help for script sqwsyb_UpdtStatsAllDatabases.ksh:
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -h
#Affichage de l'aide en ligne pour ce script
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.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_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -s
#Affichage des exemples d'utilisation pour ce script
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY
#Genere les comamndes mais ne les execute pas !
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -Exec
#Execute le script sqwsyb_UpdtStatsDatabase.ksh pour faire un update index statistics sur toutes les databases
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -Dist -Exec
#Analyse toutes les tables de toutes les bases avec une connexion distante pour l'instance non-locale $DSQUERY
#Vous devez saisir toutes les informations d'authentification a utiliser pour la connexion distante a l'instance dans le fichier $gvsqw_DistPasswdFile
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -Hashing -HashSize <NumericValue> -Exec
#Active le hashage avec une taille de 1000000 Mo (par defaut, $gvsqw_HashSize)
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -NoHashing -Exec
#Desactive le hashing (par defaut, gvsqw_WithHashing='False')
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -SizeMaxTable -Exec
#Update les stats uniquement des tables de maximum 1000000 Mo (par defaut, $gvsqw_DefSizeMaxTableUpdtStats)
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -MinPctChange <NumericValue> -Exec
#Lance un update index statistics sur les tables modifies d'au moins $lvsqw_MinPctChange %
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -Del -Exec
#Supprime les stats avant de les recalculer: 'delete statistics $lvsqw_Owner.$lvsqw_Table'
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -Type <Type> -Exec
#Execute les commandes generees et change le type de statistics ('default','index','table','all')
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -AGR 20 -Exec
#Reglage du temps d'attente en secondes entre deux lancements de commandes, 20s ici
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -AGE 30 -Exec
#Reglage du temps d'attente en secondes entre deux check de fin, 30s ici
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -ID 'DbName1,DbName2' -Exec
#Execute les commandes generees pour seulement les 2 bases de donnees specifiees
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -ED 'DbName3,DbName4' -Exec
#Execute les commandes generees sauf pour les 2 bases de donnees specifiees
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -IL '%_PROD' -Exec
#Clause like pour generee une liste dynamique de bases a inclure (exemple: 'dbprod%')
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -EL '%_TESTS' -Exec
#Clause like pour generee une liste dynamique de bases a exclure (exemple: 'dbtest%')
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -WCD '<condition>' -Exec
#Clause where pour generee une liste dynamique de bases a inclure
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -P <NumericValue> -Exec
#Execute le script sqwsyb_UpdtStatsDatabase.ksh avec un degre de parallelisme de '<NumericValue>'
#Utilise par defaut la variable gvsqw_NbThreadXXX dans $gvsqw_SybBin/../etc/sqwpg_GlobalVar.cfg
#Vous pouvez changer le defaut sur tout l'environnement si vous settez cette variable
#dans le fichier de configuration $gvsqw_SybBin/../etc_cust/sqwpg_GlobalVar.cfg
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -AddMail 'mymail1@mydomaine.com,mymail2@mydomaine.com' -Exec
#Ajoute la liste de mail a l'adresse par defaut geree par $gvsqw_GlobalMail
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -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_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -NoMail -Exec
#Desactive l'envoi de mail sur erreur a $gvsqw_GlobalMail (par defaut, seulement en cas d'erreur)
$gvsqw_SybBin/sqwsyb_UpdtStatsAllDatabases.ksh -I $DSQUERY -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_sqwsyb_UpdtStatsAllDatabases=<NumericValue>
#dans le fichier de configuration $gvsqw_SybBin/../etc_cust/sqwsyb_GlobalVar.cfg
