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 :

problème shared_pool_size volumineuse


Sujet :

Administration Oracle

  1. #1
    Membre éclairé Avatar de Z3phur
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2007
    Messages : 680
    Points : 807
    Points
    807
    Par défaut problème shared_pool_size volumineuse
    Bonjour,

    je suis sous oracle 10.2.0.4, et je me retrouve avec une taille de share_pool surdimensionné plus de 8Go.

    avec la requete suivante :

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    16
    17
    18
    COL "Total octets alloués" FORMAT A20
    COL "octets utilisés" FORMAT A20
    COL "octets libres" FORMAT A20
    SELECT
           a.POOL "Pool"
        , b.Octets || ' (' || ROUND(b.Octets/1024/1024) || ' Mo)' "Total octets alloués"
        , (b.Octets-a.BYTES) || ' (' || ROUND((b.Octets-a.BYTES)/1024/1024) || ' Mo)' "octets utilisés"
        , a.BYTES || ' (' || ROUND(a.BYTES/1024/1024) || 'Mo)' "octets libres"
    FROM   V$SGASTAT a,
           (  SELECT POOL, SUM(BYTES) Octets, SUM(BYTES/1024/1024) Mo
              FROM V$SGASTAT
              WHERE POOL IS NOT NULL
              GROUP BY POOL
              ORDER BY POOL) b
    WHERE  NAME = 'free memory'
    AND    a.POOL = b.POOL
    AND a.POOL = 'shared pool'
    ORDER BY a.POOL ;
    j'ai le résultat suivant :

    Pool Total octets alloué octets utilisés octets libres
    ------------ -------------------- -------------------- --------------------
    shared pool 8850879392 (8441 Mo) 3773790552 (3599 Mo) 5077088840 (4842Mo)
    Pouvez-vous me dire comment récupérer l'espace non utilisé??? Je bute vraiment car même en prenant la main sur le redimensionnement je n'arrive pas à réduire la taille
    ==========================================
    La justice sans la force est impuissante, la force sans la justice est tyrannique...

  2. #2
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Quel est le système d'exploitation exact que vous utilisez ?

    Que donne:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    SQL> select * from v$sgainfo;
    SQL> show parameter sga_target
    SQL> show parameter sga_max

  3. #3
    Membre éclairé Avatar de Z3phur
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2007
    Messages : 680
    Points : 807
    Points
    807
    Par défaut
    Bonjour,

    l'os exact est : Red Hat Enterprise Linux AS release 4 (Nahant Update 6)

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    11
    12
    13
    14
    15
    SQL> SELECT * FROM v$sgainfo;
     
    NAME				      BYTES RES
    -------------------------------- ---------- ---
    Fixed SGA Size			    2101736 No
    Redo Buffers			   31449088 No
    Buffer Cache Size		 4781506560 Yes
    Shared Pool Size		 5754585088 Yes
    Large Pool Size 		   16777216 Yes
    Java Pool Size			  117440512 Yes
    Streams Pool Size		   16777216 Yes
    Granule Size			   16777216 No
    Maximum SGA Size		 1.0737E+10 No
    Startup overhead in Shared Pool   234881024 No
    Free SGA Memory Available	   16777216
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SQL>SHOW parameter sga_target
     
    NAME				     TYPE
    ------------------------------------ ---------------
    VALUE
    ------------------------------
    sga_target			     big integer
    10G
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    5
    6
    7
    8
    SQL> SHOW parameter sga_max
     
    NAME				     TYPE
    ------------------------------------ ---------------
    VALUE
    ------------------------------
    sga_max_size			     big integer
    10G
    Merci pour ton aide
    ==========================================
    La justice sans la force est impuissante, la force sans la justice est tyrannique...

  4. #4
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Vous pouvez modifier dynamiquement SGA_TARGET mais je ne pense pas que la mémoire est effectivement libérée par Oracle et rendue à Linux tant que SGA_MAX_SIZE n'est pas modifié (je crois que c'est le cas pour Solaris pour les Unix). Modifier SGA_MAX_SIZE nécessite de redémarrer l'instance.

    Je ne suis pas sûr que votre requête donne le bon résultat.
    Que donne:

    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    select * from (
    select pool, name, sum(bytes/1024/1024) 
    from v$sgastat group by pool,name ) 
    where name like '%free%';

  5. #5
    Membre éclairé Avatar de Z3phur
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2007
    Messages : 680
    Points : 807
    Points
    807
    Par défaut
    Merci pifor,

    je verrais cela un peu plus en profondeur demain.
    ==========================================
    La justice sans la force est impuissante, la force sans la justice est tyrannique...

  6. #6
    Membre éclairé Avatar de Z3phur
    Homme Profil pro
    Administrateur de base de données
    Inscrit en
    Décembre 2007
    Messages
    680
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Âge : 49
    Localisation : France, Val de Marne (Île de France)

    Informations professionnelles :
    Activité : Administrateur de base de données
    Secteur : Industrie

    Informations forums :
    Inscription : Décembre 2007
    Messages : 680
    Points : 807
    Points
    807
    Par défaut
    Merci pifor des efforts que tu mets pour m'aider,

    voici le résultat de la requête :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
    SELECT * FROM (
    SELECT pool, name, sum(bytes/1024/1024) 
    FROM v$sgastat GROUP BY pool,name ) 
    WHERE name LIKE '%free%';
    streams pool free memory 15.9985046
    shared pool message pool freequeue .91053772
    shared pool free memory 5120.20004
    shared pool ksuloi: long op free list .000244141
    shared pool kghx free lists .047851563
    shared pool sim kghx free lists 7.6294E-06
    shared pool kglsim free heap list .000389099
    java pool free memory 112
    shared pool kglsim free obj list .000389099
    large pool free memory .740913391
    ==========================================
    La justice sans la force est impuissante, la force sans la justice est tyrannique...

  7. #7
    Membre expert

    Profil pro
    Inscrit en
    Février 2006
    Messages
    3 437
    Détails du profil
    Informations personnelles :
    Localisation : France

    Informations forums :
    Inscription : Février 2006
    Messages : 3 437
    Points : 3 597
    Points
    3 597
    Par défaut
    Effectivement vous pouvez probablement réduire la taille du shared pool en réduisant SGA_TARGET. Ceci dit, je conseille dans un premier temps de réduire uniquement SGA_TARGET dynamiquement sans toucher à SGA_MAX_SIZE: ce qui peut permettre d'augmenter SGA_TARGET en cas d'erreur inattendue ORA-04031 (il y a quelques bugs à ce sujet en 10.2.0.x). Idéalement, il faudrait faire un test de charge pour confirmer.

+ Répondre à la discussion
Cette discussion est résolue.

Discussions similaires

  1. [phpMyAdmin] problème importation base volumineuse
    Par sky88 dans le forum EDI, CMS, Outils, Scripts et API
    Réponses: 5
    Dernier message: 23/05/2012, 17h45
  2. Réponses: 2
    Dernier message: 25/02/2011, 10h39
  3. problèmes mysqldump sur une table volumineuse
    Par lucho.66 dans le forum MySQL
    Réponses: 1
    Dernier message: 03/07/2009, 20h35
  4. Réponses: 1
    Dernier message: 17/07/2007, 13h05
  5. Problème d'installation oracle 8.1.7 sous NT
    Par Anonymous dans le forum Installation
    Réponses: 7
    Dernier message: 02/08/2002, 14h18

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