zt_oracle shared pool分配机制_4031

/*****shared pool 分配机制chunk_bucket********/
http://book.chinaz.com/Oracle/7619.shtml


/*******查看共享池各种状态chunk的分配信息*********/
SQL> select  ksmchcls,sum(ksmchsiz) from x$ksmsp group by ksmchcls;
 
KSMCHCLS SUM(KSMCHSIZ)
-------- -------------
recr          28187472
freeabl       38621808
R-freea           3840
perm          63683040
R-free        11866000
R-perm        20537992
free            891296
R-recr         3977192
 
8 rows selected

/****oracle在启动时并未把全部的共享池大小分配给共享,而是留了一部分,待以后再分配,防止出现过多的碎片和后来大的共享请求*****/
SQL> select * from v$sgastat where name like '%free%' and name='free memory';
 
POOL         NAME                            BYTES
------------ -------------------------- ----------
shared pool  free memory                 218738520

/*******超过5000byte大小的共享池请求才会使用/
一般,最大的Chunks也不会超过5000bytes的.假如有请求更大的Chunks的话,Oracle用的是另外一种方式,即下面说的Reserved Shared Pool,
而不会到Shared Pool Free Lists和LRU Lists中寻找适应的或者更大SIZE的Chunks来给它使用.
SQL> show parameter reser
 
NAME                                 TYPE        VALUE
------------------------------------ ----------- ------------------------------
shared_pool_reserved_size            big integer 8M

小结:1,先在free list找可用的chunk
     2,其次在lru list找可用的chunk
     3,最后在reserved list找可用的chunk

请使用浏览器的分享功能分享到微信等