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 :

ORA-04031: impossible d'affecter 32 octets de memoire partagée


Sujet :

Administration Oracle

  1. #1
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Juillet 2015
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2015
    Messages : 7
    Points : 2
    Points
    2
    Par défaut ORA-04031: impossible d'affecter 32 octets de memoire partagée
    Bonjour,

    L'éditeur d'un logiciel qui utilise une des bases oracle nous a demandé de changer des paramètres liés à la mémoire.

    les paramètre initiaux :
    memory_target 60G
    memory_max_target 88G
    sga_target 48G
    sga_max_size 88G
    pga_aggregate_target 9000M
    db_cache_size 512M
    shared_pool_size 512M

    et les paramètres demandés :
    memory_target 10G
    memory_max_target 88G
    sga_target 0
    sga_max_size 88G
    pga_aggregate_target 1000M
    db_cache_size 3000M
    shared_pool_size 500M

    sauf que quand je démarre avec ces paramètres (compris dans un pfile)
    j'ai le message d'erreur suivant : ORA-04031: impossible d'affecter 32 octets de memoire partagee ("shared pool","unknown object","KGLH0^940b3db9","kglHeapInitialize:temp")

    si jamais vous avez une idée je suis preneur...

  2. #2
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    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 460
    Points : 8 074
    Points
    8 074
    Par défaut
    En quelle version êtes-vous ?

    Car vous devriez tomber sur l'erreur suivante autant avec l'ancien paramétrage que le nouveau :
    ORA-00851: SGA_MAX_SIZE xxx cannot be set to more than MEMORY_TARGET xxx.

    Pour votre ORA-04031, la logique que j'y vois est la suivante :
    Dans l'ancien paramétrage, la zone "shared pool" avait une taille de 512M au moins (assurée par SHARED_POOL_SIZE), mais automatiquement extensible dans la limite de SGA_TARGET (48 G).
    Dans le paramétrage actuel, le dimensionnement automatique des zones de la SGA est désactivé (SGA_TARGET=0), donc la zone "shared pool" a désormais une taille fixe de 500M (SHARED_POOL_SIZE), ce qui est sans doute bien trop petit.

    Pour moi, activer le dimensionnement automatique au niveau global (MEMORY_TARGET > 0) mais le désactiver au niveau de la SGA (SGA_TARGET=0) n'a aucun intérêt, et je serais curieux d'en connaître la justification.
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

  3. #3
    Candidat au Club
    Homme Profil pro
    Administrateur systèmes et réseaux
    Inscrit en
    Juillet 2015
    Messages
    7
    Détails du profil
    Informations personnelles :
    Sexe : Homme
    Localisation : France, Eure (Haute Normandie)

    Informations professionnelles :
    Activité : Administrateur systèmes et réseaux
    Secteur : Santé

    Informations forums :
    Inscription : Juillet 2015
    Messages : 7
    Points : 2
    Points
    2
    Par défaut
    Nous sommes en 11.2.0.3 si je ne me trompe pas.

    Je vous avouerai que je fais du dépannage car mon collègue est vacances et que mes connaissances sur la partie mémoire est assez limitée.

    Concernant les valeurs je les applique un peu bêtement à vrai dire. Je n'en connais absolument pas la justification.
    J'ai essayé en mettant une shared_pool_size à 1000M mais j'ai le même message d'erreur. Peut être faudrait il mettre plus ?

  4. #4
    Rédacteur

    Homme Profil pro
    Consultant / formateur Oracle et SQL Server
    Inscrit en
    Décembre 2002
    Messages
    3 460
    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 460
    Points : 8 074
    Points
    8 074
    Par défaut
    Comme on ne connaît pas les tenants et aboutissants de ces modifications, la seule chose que je puisse vous suggérer, c'est de vous retourner vers votre éditeur puisque ses recommandations ne sont pas applicables.
    Consultant / formateur Oracle indépendant
    Certifié OCP 12c, 11g, 10g ; sécurité 11g

    Ma dernière formation Oracle 19c publiée sur Linkedin : https://fr.linkedin.com/learning/oracle-19c-l-administration

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

    Informations professionnelles :
    Activité : xxxxxxxxx

    Informations forums :
    Inscription : Avril 2015
    Messages : 394
    Points : 552
    Points
    552
    Par défaut gestion_memoires
    Je te suggère que tu réstaure le paramètrage initial des composantes mémoires de ta base, en suite tu reprendre
    seulement la modification du paramètre memory_target_size, et de sga_target en abaissant entre -10% et -15% de la valeur initiale,
    en suite après redémarrage de ta base, vérifie bien ton paramètrage sur ces vues suivantes :
    Code : Sélectionner tout - Visualiser dans une fenêtre à part
    1
    2
    3
    4
     
    select * from v$memory_dynamic_components ;
    select * from v$sga_dynamic_free_memory;
    select * from v$sgastat ;
    et l'information de la vue v$sga_dynamic_free_memory te donnera la mémoire disponible dans la sga, qui te servira pour l'augmentation de shared pool

    Cordialement

Discussions similaires

  1. Erreur ORA-04031 , panique
    Par arsenik7 dans le forum Oracle
    Réponses: 11
    Dernier message: 30/06/2006, 13h52
  2. Réponses: 2
    Dernier message: 23/06/2006, 20h34
  3. Réponses: 4
    Dernier message: 10/04/2006, 22h34
  4. [ORA-04031 :] AVoir une SHARED_POOL propre.
    Par Apsolu dans le forum Oracle
    Réponses: 6
    Dernier message: 24/03/2006, 10h55
  5. Impossible d'affecter un événement
    Par Costello dans le forum Composants VCL
    Réponses: 2
    Dernier message: 21/08/2005, 16h18

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