Skip to content
pvmehta.com

pvmehta.com

  • Home
  • About Me
  • Toggle search form
  • AWR settings- MMON is not taking snapshot. Oracle
  • Example of How To Resize the Online Redo Logfiles Note:1035935.6 Oracle
  • Unix command for system configuration Linux/Unix
  • Implementing Listener Security Oracle
  • plan10g.sql good1 Oracle
  • Default User Profile Oracle
  • Specify the Rollback segment to use in Transaction Oracle
  • Drop tempfiles from database Oracle
  • Set Role explaination. Oracle
  • How to check current redo log progress redo_progress.sql Oracle
  • Good Site for Oracle Internals Oracle
  • ORA-3136 Oracle
  • Find Time Consuming SQL Statements in Oracle 10g Oracle
  • ORA-8031 issue and solution if it is occuring due to truncate. Oracle
  • Rename Tablespace Oracle

Another Tuning Article for subheap of shared pool

Posted on 16-Feb-2007 By Admin No Comments on Another Tuning Article for subheap of shared pool

http://www.mail-archive.com/oracle-l@fatcity.com/msg79721.html

Oh yeah, I forgot to say that in 9.2.0.3 the shared pool was broken up into “heaps” (Oracle terminology) but whatever fancy stuff they were trying to accomplish by doing this (I think part of the magical self-tuning initiative) was buggy and this hastened the fatal 4031 situation. There is a parameter (so I have been told) Shared pool has always been a heap (inside SGA heap, and can contain heaps as well if requested). Shared pool heap is physically divided to equal sized extents. But space inside shared pool heap is allocated in “chunks” and there are freelists&lru lists for tracking free and unpinned recreable

tchunks. There is actually 255 freelists, each for different allocation size range, starting from 16 bytes up to about 64+ kilobytes. Depending on how much memory allocation request has been made, the proper freelist is scanned. When matching size chunks aren’t found, the closest match is split. Anyway, lets call these 255 freelists a shared pool “freelist set” (don’t

know the correct Oracle term). But people often suffer from shared pool latch contention when a lot of shared pool memory allocation occurs (no bind variables are used in SQL etc etc).

Lots of concurrent memory allocation requests mean lots of processes trying to acquire shared pool latch and scan through relevant freelist, if no sufficiently large chunk found, then LRU list as well. During these operations, the shared pool latch is being hold by session doing the scanning causing shared pool latch contention. Various “experts” suggesting to increase your shared pool make the situation even worse, because in time, the LRU and freelists get even longer, thus

one scan takes more time to complete or fail.

_kghsidx_count = 1

(The correct name is _kghdsidx_count)

So, in 9i Oracle introduced the ability to create several heaps for

serving

shared pool. If you’ve set the shared_pool_size to 64M and

_kghdsidx_count

to 4, you’ll have 4*16M shared pool heaps, every heap having its own

descriptor, extents, LRU lists, freelists and shared pool child latch

(there

is no such child latch in 8i). Shorter lists mean faster scanning, more

latches mean more scalability when serializing access to a resource. The

downside is, that usually the “resource” has to be split that every latch

protects one and only one part of resource. Thus if the shared pool is

split

into 4 parts and all memory allocation requests happen to use the same

freelist for some reason, only 25% of memory can be used. This is the

reason

why you can avoid ORA-4031s when setting _kghsidx_count to 1 – this

practically enables the old behaviour.

In 8i there is only one set of freelists, in 9i there can be more sets,

default is 1 and max limit is 7 as far as simple testing on my

9.2.0.4/W2k

has showed – I have only 7 shared pool child latches and didn’t find a

way

to increase them.

When you increase _kghdsidx_count, you see more lines in x$kghlu as well,

one for each heap (normally there was only one). Also you can verify the

behaviour when taking SGA heapdump at level 2 and search for “HEAP DUMP”

or

“FREE LISTS” in trace, there are as many free lists in dump, as you’ve

stated with _kghdsidx_count init parameter. (there is one “extra” heap in

dump, this is the SGA parent heap for shared pool heaps).

that makes the shared pool one big memory area.

One of the “fixes” in 9.2.0.4 is to make this the default now (so I

have

been told).

Can’t get my hands oon 9.2.0.2 or 0.3, but in 0.4 (on Windows), the

_kghsidx_count defaults to 1 anyway, check it out on your systems.

Tanel.

Oracle, SQL scripts

Post navigation

Previous Post: good note for shared pool tunnig
Next Post: To Find Orphan OS processes.

Related Posts

  • Drop all SPM baselines for SQL handle Oracle
  • CTAS with LONG Column for 9i and higher Oracle
  • PLSQL Table Syntax 2 Oracle
  • When error comes for temporary tablespace with version <= 9i Oracle
  • Find All internal Parameters Oracle
  • Oracle Statspack survival Guide 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 (149)
  • MYSQL (5)
  • Oracle (393)
  • PHP/MYSQL/Wordpress (10)
  • POSTGRESQL (1)
  • Power-BI (0)
  • Python/PySpark (7)
  • RAC (17)
  • rman-dataguard (26)
  • shell (149)
  • SQL scripts (342)
  • SQL Server (6)
  • Uncategorized (0)
  • Videos (0)

Recent Posts

  • Complete Git Tutorial for Beginners25-Dec-2025
  • Postgres DB user and OS user.25-Dec-2025
  • Trace a SQL session from another session using ORADEBUG30-Sep-2025
  • SQL Server Vs Oracle Architecture difference25-Jul-2025
  • SQL Server: How to see historical transactions25-Jul-2025
  • SQL Server: How to see current transactions or requests25-Jul-2025
  • T-SQL Vs PL/SQL Syntax25-Jul-2025
  • Check SQL Server edition25-Jul-2025
  • Checking SQL Server Version25-Jul-2025
  • Oracle vs MYSQL Architecture differences (For DBAs)24-Jul-2025

Archives

  • 2025
  • 2024
  • 2023
  • 2010
  • 2009
  • 2008
  • 2007
  • 2006
  • 2005
  • Good RAC & Standby Notes Oracle
  • ipcs -l Linux/Unix
  • Does DBMS_JOB recompute the NEXT_DATE interval after or before Oracle
  • fdisk -l explaination about Primary-Logical-Extended Partitions Linux/Unix
  • Parallel DML Oracle
  • Caching sequence in Memory Oracle
  • find_cons.sql Oracle
  • Zip and unzip with tar Linux/Unix

Copyright © 2026 pvmehta.com.

Powered by PressBook News WordPress theme