Skip to content
pvmehta.com

pvmehta.com

  • Home
  • About Me
  • Toggle search form
  • USE_NL and INDEX hints example Oracle
  • Deleting first line and lastline of a file using sed Linux/Unix
  • exp syntax in oracle 10g Oracle
  • Giving Grant on v$DATABASE Oracle
  • Passing from Unix to PLSQL using bind variables Linux/Unix
  • Parallel DML Oracle
  • How does one SELECT a value from a table into a Unix variable? From SQL to Shell Linux/Unix
  • To check whether standby is recovering properly or not?? Oracle
  • Reading config file from other folder inside class Python/PySpark
  • Kernel Parameter setting explaination for Processes Parameter Linux/Unix
  • Formatter Explain plan Output 1 Oracle
  • How to Decide upto what level you can decrement your datafile size. ( Shrink Datafile) Oracle
  • Wait time tuning research Oracle
  • fkwoind.sql fkwoindex.sql Oracle
  • DBMS_UTILITY PACKAGE Oracle

ORA-4031 issue and solution on 09-MAY-2008

Posted on 10-May-2008 By Admin No Comments on ORA-4031 issue and solution on 09-MAY-2008

++++++++++++++++++++

Problem description

++++++++++++++++++++

Some users started getting ORA-4031. This is the eror that show following:

4031, 00000, “unable to allocate %s bytes of shared memory (“%s”,”%s”,”%s”,”%s”)”

++++++++++++++++++++++

Problem solution

++++++++++++++++++++++

We ran following query and found failues that may result into 4031.

set echo off verify off

set lines 120 pages 555

/*

V$SHARED_POOL_RESERVED_SIZE

if enough memory then

Goal : REQUEST_MISS = 0

if not enough memory to add then

REQUEST_FAILURES = 0 or not increasing

LAST_FAILURE_SIZE > shared_pool_reserved_min_alloc

AVG_FREE_SIZE > shared_pool_reserved_min_alloc

If any of above is not met the incr the shared_pool_reserved_size.

=====================================

If REQUEST_FAILURES > 0 (and increasing) and

( LAST_FAILURE_SIZE > shared_pool_reserved_min_alloc

or MAX_FREE_SIZE < shared_pool_reserved_min_alloc
or FREE_MEMORY < shared_pool_reserved_min_alloc ) then
option:1 -> Incr shared_pool and shared_pool_reserved size

This will increase the amount of memory available on the reserved

list without impacting users not allocating memory from the reserved list.

option:2 -> Incr The shared_pool_reserved_min_alloc size

This reduces the number of allocations allowed to use memory from the

reserved list; doing so, however, will increase normal shared pool

perhaps impacting other users on the system.

end if;

Request Misses = 0 can mean the Reserved Area is too big.

Request Misses always increasing but Request Failures not increasing can mean the Reserved Area is too small.

In this case flushes in the Shared Pool satisfied the memory needs.

Request Misses and Request Failures always increasing can mean the Reserved Area is too small and

flushes in the Shared Pool are not helping (likely got an ORA-04031).

*/

prompt “SHARED_POOL_RESERVED stats”

select REQUEST_FAILURES, request_misses, LAST_FAILURE_SIZE, avg_free_size, max_free_size, free_space

from v$shared_pool_reserved;

Prompt ‘Following query shows sub-pools of shared pool from SGA’

column kghlurcr heading “RECURRENT|CHUNKS”

column kghlutrn heading “TRANSIENT|CHUNKS”

column kghlufsh heading “FLUSHED|CHUNKS”

column kghluops heading “PINS AND|RELEASES”

column kghlunfu heading “ORA-4031|ERRORS”

column kghlunfs heading “LAST ERROR|SIZE”

compute sum of kghlunfu on report

select

kghlurcr,

kghlutrn,

kghlufsh,

kghluops,

kghlunfu,

kghlunfs

from

sys.x$kghlu

/

prompt ‘Following query will return subpool wise free memory’

select addr, indx, INST_ID, KSMSSNAM, KSMSSLEN/(1024) FREE_KB, KSMDSIDX from x$ksmss where ksmssnam=’free memory’;

prompt ‘Following query will return shared pool wise free memory’

select pool, name, round(bytes/(1024)) FREE_KB from V$sgastat where POOL = ‘shared pool’ and NAME=’free memory’;

/*

KSMLRSIZ – amount of contiguous memory being allocated. Values over around 5K start to be a problem,

values over 10K are a serious problem, and values over 20K are very serious problems.

Anything less then 5K should not be a problem.

KSMLRNUM – number of objects that were flushed from the shared pool in order allocate the memory.

KSMLRHON – the name of the object being loaded into the shared pool if the object is a PL/SQL object or a cursor.

KSMLROHV – hash value of object being loaded

KSMLRSES – SADDR of the session that loaded the object

Prompt ‘Following query shows what is the query that is running and causes other parse trees to get out from shared_pool’

*/

select a.sid, a.serial#, a.machine, a.osuser, b.sql_text, c.ksmlrsiz “Allocted size” , KSMLRNUM “obj got out”

from v$sqltext b, v$session a, x$ksmlru c

where b.hash_value = a.sql_hash_value

and b.address = a.sql_address

and a.saddr = c.ksmlrses

and c.ksmlrsiz > 5000;

To resolve this issue, We changed following parametre and bounced the instance.

shared_pool_size=2147483648 # increased from 1.2G

shared_pool_reserved_size=429496730 # increased from 120M

_kghdsidx_count=2 # this is # of subpools in shared_pool (for >9i). We decrease it from 7 (default)

_shared_pool_reserved_min_alloc=4000 # this shows any allocation more than this size will goto reserved shared pool.

After bouncing the instance everything is fine and we took connections for about 2800 user sessions.

Oracle, SQL scripts

Post navigation

Previous Post: How to calculate PROCESSES parameter
Next Post: pvm_metric.sql for gathering report from vmstat tables

Related Posts

  • How to know current SID Oracle
  • moving lob object to other tablespace lob_mvmt.sql Oracle
  • OPENING A STANDBY DATABASE IN READ-ONLY MODE Oracle
  • New Latest Param.sql for finding all hidden parameters also Oracle
  • create PLAN_TABLE command. Oracle
  • DB Console Mainenance. Oracle

Leave a Reply Cancel reply

Your email address will not be published. Required fields are marked *

Categories

  • Ansible (0)
  • AWS (2)
  • Azure (1)
  • Django (0)
  • GIT (1)
  • Linux/Unix (150)
  • MYSQL (5)
  • Oracle (403)
  • PHP/MYSQL/Wordpress (10)
  • POSTGRESQL (1)
  • Power-BI (0)
  • Python/PySpark (7)
  • RAC (18)
  • rman-dataguard (26)
  • shell (151)
  • SQL scripts (349)
  • SQL Server (6)
  • Uncategorized (5)
  • Videos (0)

Recent Posts

  • Key Management in Oracle: The Core Issue: Missing Master Key12-May-2026
  • SAT Mathematics 10 questions and answer at the end.30-Apr-2026
  • top 10 AI news today30-Apr-2026
  • runon_allpdbs_show_conname.sh23-Apr-2026
  • runon_allcdbs_find_pdbs.sh23-Apr-2026
  • Running PDB on single node in RAC09-Apr-2026
  • find_arc.sql09-Apr-2026
  • pvm_pre_change.sql08-Apr-2026
  • find_encr_wallet.sql08-Apr-2026
  • find_pdbs.sql08-Apr-2026

Archives

  • 2026
  • 2025
  • 2024
  • 2023
  • 2010
  • 2009
  • 2008
  • 2007
  • 2006
  • 2005
  • find_idle_cpu.sql Oracle
  • Implementation of key based authentications Linux/Unix
  • Oracle 10g Installation/Applying Patches Tips Oracle
  • rm_backup_arch_file.ksh Linux/Unix
  • sql_doing_fts.sql Oracle
  • SQL_PROFILE – I explaination Oracle
  • Jai Shree Ram Oracle
  • On solaris 10, “S” link is not part of $ORACLE_HOME/bin/oracle as default. ( For 9.2.0.8) Oracle

Copyright © 2026 pvmehta.com.

Powered by PressBook News WordPress theme