IdentifiantMot de passe
Loading...
Mot de passe oublié ?Je m'inscris ! (gratuit)
Navigation

Inscrivez-vous gratuitement
pour pouvoir participer, suivre les réponses en temps réel, voter pour les messages, poser vos propres questions et recevoir la newsletter

Administration Oracle Discussion :

Historique sur les tablespaces


Sujet :

Administration Oracle

  1. #1
    Membre averti
    Profil pro
    Inscrit en
    Novembre 2008
    Messages
    20
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Novembre 2008
    Messages : 20
    Par défaut Historique sur les tablespaces
    Bonjour,

    J'aimerais savoir comment peut voir l'historique d'un agrandissement de tablespace ?

    Merci

  2. #2
    Rédacteur/Modérateur

    Avatar de Fabien Celaia
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Octobre 2002
    Messages
    4 227
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 54
    Localisation : Suisse

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Service public

    Informations forums :
    Inscription : Octobre 2002
    Messages : 4 227
    Billets dans le blog
    25
    Par défaut
    Il y a le mode bricole : tu tournes un script chaque semaine qui te sauve la taille de l''utilisation de tes tablespaces dans une table.
    A ma connaissance, il n'y a pas d'historisation de l'augmentation des tailles.
    Sr DBA Oracle / MS-SQL / MySQL / Postgresql / SAP-Sybase / Informix / DB2

    N'oublie pas de consulter mes articles, mon blog, les cours et les FAQ SGBD

    Attention : pas de réponse technique par MP : pensez aux autres, passez par les forums !

  3. #3
    Membre Expert
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2013
    Messages
    2 005
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 2 005
    Par défaut
    Citation Envoyé par pierho34 Voir le message
    Bonjour,
    J'aimerais savoir comment peut voir l'historique d'un agrandissement de tablespace ?
    Utilise dbms_metadata.get_ddl pour récupérer l'ordre de créationd e ton tablespace.
    Normalement tu verras le ALTER TABLESPACE...RESIZE mais sans la date de l'opération.

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    SELECT DBMS_METADATA.GET_DDL('TABLESPACE', 'USER_DATA') FROM DUAL;
    
    DBMS_METADATA.GET_DDL('TABLESPACE','USER_DATA')                                 
    --------------------------------------------------------------------------------
      CREATE TABLESPACE "USER_DATA" DATAFILE                                        
      '/*****/oradata02/*****/*****_USER_DATA_01.dbf' SIZE 104857600         
      AUTOEXTEND ON NEXT 104857600 MAXSIZE 30720M                                   
      LOGGING ONLINE PERMANENT BLOCKSIZE 8192                                       
      EXTENT MANAGEMENT LOCAL AUTOALLOCATE DEFAULT                                  
     NOCOMPRESS  SEGMENT SPACE MANAGEMENT AUTO                                      
       ALTER DATABASE DATAFILE                                                      
      '/*****/oradata02/*****/*****_USER_DATA_01.dbf' RESIZE 13203668992     
    1 row selected.

  4. #4
    Membre chevronné
    Homme Profil pro
    xxxxxxxxx
    Inscrit en
    Avril 2015
    Messages
    394
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : xxxxxxxxx

    Informations forums :
    Inscription : Avril 2015
    Messages : 394
    Par défaut
    Il existe le paramètre de l'instance qui permet de consigner les modifications des tailles de tablespace , essaye de voir est-ce que ça fonctionne ? ?
    Le parametre ENABLE_DDL_LOGGING=TRUE

  5. #5
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 461
    Par défaut
    La solution de choix si vous êtes en édition Entreprise, c'est la vue DBA_HIST_TBSPC_SPACE_USAGE qui vous fournira l'évolution de la volumétrie.
    Mais attention, vous devez avoir acquis la licence pour le "diagnostics pack" pour avoir le droit d'utiliser cette vue.
    Si vous ne remplissez pas les conditions, il faudra gérer vos propres tables d'historisation comme suggéré par Fabien.

    Sinon, les extensions de tablespaces, manuelles ou automatiques, sont tracées dans l'alert.log, mais ce n'est guère commode à exploiter.
    (Et si vous purgez régulièrement l'alert.log comme c'est d'usage, l'historique sera probablement insuffisant).


    Concernant ENABLE_DDL_LOGGING, ce paramètre n'agit pas sur les tablespaces d'après la documentation.
    Et, cerise (très amère) sur le gâteau, il exige la licence "
    Database Lifecycle Management Pack"




  6. #6
    Membre chevronné
    Homme Profil pro
    xxxxxxxxx
    Inscrit en
    Avril 2015
    Messages
    394
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : xxxxxxxxx

    Informations forums :
    Inscription : Avril 2015
    Messages : 394
    Par défaut
    en ajoutant la solution d'audit des tablespaces, ça ira aussi !!

  7. #7
    Membre Expert
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2013
    Messages
    2 005
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 2 005
    Par défaut
    Citation Envoyé par dell68 Voir le message
    en ajoutant la solution d'audit des tablespaces, ça ira aussi !!
    Peux-tu détailler? Tu audites quoi précisément? Comment : avec l'audit classique, avec l'audit de granularité fine DBMS_FGA...

  8. #8
    Membre chevronné
    Homme Profil pro
    xxxxxxxxx
    Inscrit en
    Avril 2015
    Messages
    394
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : xxxxxxxxx

    Informations forums :
    Inscription : Avril 2015
    Messages : 394
    Par défaut
    La liste des objets à auditer est ici, et parmi eux tu trouveras les opérations du tablespace :
    https://docs.oracle.com/cd/E11882_01...htm#SQLRF01107

  9. #9
    Membre Expert
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2013
    Messages
    2 005
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 2 005
    Par défaut
    Merci pour le lien.

    Sinon on peut aussi faire un trigger system sur l'évènement "Before/After DDL".
    Attention à bien récupérer les variables d'environnement de ce trigger pour filtrer sur l'ordre DDL.
    https://www.morganslibrary.org/refer...l_trigger.html

  10. #10
    Membre chevronné
    Homme Profil pro
    xxxxxxxxx
    Inscrit en
    Avril 2015
    Messages
    394
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 56
    Localisation : France, Rhône (Rhône Alpes)

    Informations professionnelles :
    Activité : xxxxxxxxx

    Informations forums :
    Inscription : Avril 2015
    Messages : 394
    Par défaut
    Pour réctifier ce qu'il a déclaré Pomalaix sur la paramètre ENABLE_DDL_LOGGING, je viens de le tester sur une base 19c sous windows,
    il agit bien les opérations d'un TABLESPACE, le fichier généré en format xml est dans le dossier :
    F:\app\admin\diag\rdbms\test\test\log\ddl
    Good luck !!!!

  11. #11
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 461
    Par défaut
    Citation Envoyé par dell68 Voir le message
    Pour réctifier ce qu'il a déclaré Pomalaix sur la paramètre ENABLE_DDL_LOGGING, je viens de le tester sur une base 19c sous windows...
    Bien vu ! En effet, bien que la doc ne le mentionne pas, les tests montrent que ENABLE_DDL_LOGGING enregistre aussi les commandes explicites relatives aux fichiers et tablespaces.

    On constate aussi que les commandes implicites (agrandissement automatique d'un fichier en autoextension) ne sont pas enregistrées via ce paramètre. Et ceci paraît tout à fait normal.
    A l'inverse, un agrandissement automatique est tracé spontanément dans l'alert.log sans avoir besoin d'un tel paramètre.

    Si l'objectif c'est d'obtenir l'historique de la volumétrie des tablespaces, j'en reste à ma première réponse :
    - DBA_HIST_TBSPC_SPACE_USAGE sous réserve d'être en édition Entreprise avec la licence Diagnostics pack
    - mécanique créée de toute pièce (mais simple à mettre en place par un simple SELECT / INSERT) qui va enregistrer automatiquement dans une table de suivi, la volumétrie des tablespaces, à intervalle régulier, par exemple une fois par jour.

    Les "solutions" à base d'analyse d'alert.log, de paramètre ENABLE_DDL_LOGGING ou d'audit, sont à oublier, car elles sont incapables de répondre au besoin de manière simple et complète.

  12. #12
    Membre Expert
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2013
    Messages
    2 005
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 2 005
    Par défaut
    Citation Envoyé par Pomalaix Voir le message
    Les "solutions" à base d'analyse d'alert.log, de paramètre ENABLE_DDL_LOGGING ou d'audit, sont à oublier, car elles sont incapables de répondre au besoin de manière simple et complète.
    Et le trigger système DDL dont je parlais? Actuellement je manque de temps pour tester cette piste mais elle ne me semble pas bête, loin s'en faut.

  13. #13
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 461
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Var (Provence Alpes Côte d'Azur)

    Informations professionnelles :
    Activité : Consultant / formateur Oracle et SQL Server

    Informations forums :
    Inscription : Décembre 2002
    Messages : 3 461
    Par défaut
    Citation Envoyé par Ikebukuro Voir le message
    Et le trigger système DDL dont je parlais? Actuellement je manque de temps pour tester cette piste mais elle ne me semble pas bête, loin s'en faut.
    Disons qu'on a un fichier prédimensionné à 10 Go, et contenant pour l'instant 1 Go de données.
    Votre système sera-t-il capable d'identifier l'évolution de l'espace occupé alors qu'il n'y a pas d'agrandissement du fichier ?

  14. #14
    Membre Expert
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Avril 2013
    Messages
    2 005
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Paris (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : High Tech - Produits et services télécom et Internet

    Informations forums :
    Inscription : Avril 2013
    Messages : 2 005
    Par défaut
    Ah, je croyais que la question était sur un ALTER TABLESPACE ... RESIZE pour suivre l'évolution d'augmentatio nde la taille d'un tbs.
    A priori c'est l'évolution de la consommation de l'espace dans le tablespace.

Discussions similaires

  1. Informations sur les tablespaces
    Par SheikYerbouti dans le forum Contribuez
    Réponses: 0
    Dernier message: 30/12/2011, 14h24
  2. Trigger d'historique sur les relations
    Par Grotoumaigr dans le forum Requêtes
    Réponses: 2
    Dernier message: 09/03/2011, 08h09
  3. Réponses: 1
    Dernier message: 29/04/2009, 02h41
  4. questions sur les tablespaces
    Par tro2blabla dans le forum Administration
    Réponses: 2
    Dernier message: 11/03/2009, 13h47

Partager

Partager
  • Envoyer la discussion sur Viadeo
  • Envoyer la discussion sur Twitter
  • Envoyer la discussion sur Google
  • Envoyer la discussion sur Facebook
  • Envoyer la discussion sur Digg
  • Envoyer la discussion sur Delicious
  • Envoyer la discussion sur MySpace
  • Envoyer la discussion sur Yahoo