Oracle程序全局区(PGA)(二)

2014-11-24 17:03:34 · 作者: · 浏览: 1
et_for_estimate, to_char(pga_target_factor * 100,'999.9') ||'%' pga_target_factor, trunc(bytes_processed/1024/1024) bytes_processed, trunc(estd_extra_bytes_rw/1024/1024) estd_extra_bytes_rw, to_char(estd_pga_cache_hit_percentage,'999') || '%' estd_pga_cache_hit_percentage, estd_overalloc_count from v$pga_target_advice; SQL> select 2 trunc(pga_target_for_estimate/1024/1024) pga_target_for_estimate, 3 to_char(pga_target_factor * 100,'999.9') ||'%' pga_target_factor, 4 trunc(bytes_processed/1024/1024) bytes_processed, 5 trunc(estd_extra_bytes_rw/1024/1024) estd_extra_bytes_rw, 6 to_char(estd_pga_cache_hit_percentage,'999') || '%' estd_pga_cache_hit_percentage, 7 estd_overalloc_count 8 from v$pga_target_advice; PGA_TARGET_FOR_ESTIMATE PGA_TAR BYTES_PROCESSED ESTD_EXTRA_BYTES_RW ESTD_ ESTD_OVERALLOC_COUNT ----------------------- ------- --------------- ------------------- ----- -------------------- 40 12.5% 600 41 93% 7 81 25.0% 600 8 99% 3 162 50.0% 600 0 100% 0 243 75.0% 600 0 100% 0 324 100.0% 600 0 100% 0 388 120.0% 600 0 100% 0 453 140.0% 600 0 100% 0 518 160.0% 600 0 100% 0 583 180.0% 600 0 100% 0 648 200.0% 600 0 100% 0 972 300.0% 600 0 100% 0 PGA_TARGET_FOR_ESTIMATE PGA_TAR BYTES_PROCESSED ESTD_EXTRA_BYTES_RW ESTD_ ESTD_OVERALLOC_COUNT ----------------------- ------- --------------- ------------------- ----- -------------------- 1296 400.0% 600 0 100% 0 1944 600.0% 600 0 100% 0 2592 800.0% 600 0 100% 0 14 rows selected.

这里可以看到162M就可以实现PGA命中率100%
5、手动PGA内存管理与自动PGA内存管理
自动PGA内存管理相对于手动PGA内存管理有很多优点
1, 当用户连接少时
a) 手动PGA内存管理不管有多少可用内存都按照预设值进行分配。比如当前空闲内存为300MB,连接需要10MB的内存进行排序,而我们设定的排序区大小为5MB,导致虽然有足够的空闲内存却无法分配给当前连接,造成执行效率低下。
b) 自动PGA内存管理会根据当前空闲内存来进行分配。当空闲内存为300MB,当前用户需要10MB内存进行排序,Oracle就会分配10MB内存给当前用户。
2, 当用户连接多时
a) 手动PGA内存管理会完全按照预设值分配内存。如果物理内存总量为1G,排序区设为5MB,当有300个用户连接时,Oracle会分配1.5G的内存,这已经超过了我们的实际物理内存!
b) 自动PGA内存管理会根据当前连接情况进行分配。如果物理内存总量为1G,PGA_AGGREGATE_TARGET为300MB,当用户数从10升到300时,每个用户连接的内存会从满足需要的10MB慢慢减少到1.3MB,虽然最后总量也会超过PGA_AGGREGATE_TARGET,但比起手动PGA内存管理要好很多了。
什么时候使用自动PGA内存管理?什么时候使用手动PGA内存管理?
白天系统正常运行时适合使用自动PGA内存管理,让Oracle根据当前负载自动管理、分配PGA内存。
夜里用户数少、进行维护的时候可以设定当前会话使用手动PGA内存管理,让当前的维护操作获得尽可能多的内存,加快执行速度。
如:服务器平时运行在自动PGA内存管理模式下,夜里有个任务要大表进行排序连接后更新,就可以在该操作session中临时更改为手动PGA内存管理,然后分配大的SORT_AREA_SIZE和HASH_AREA_SIZE(50%甚至80%内存,要确保无其他用户使用),这样能大大加快系统运行速度,又不影响白天高峰期对系统造成的影响。
6、操作命令
系统级更改:
ALTER SYSTEM SET WORKAREA_SIZE_POLICY = {AUTO | MANAUL};
ALTER SYSTEM SET PGA_AGGREGATE_TARGET=100000000;
ALTER SYSTEM SET SORT_AREA_SIZE = 65536 SCOPE = SPFILE;
ALTER SYSTEM SET HASH_AREA_SIZE = 65536 SCOPE = SPFILE;

会话级更改
ALTER SESSION SET WORKAREA_SIZE_POLICY = {AUTO | MANAUL};
ALTER SESSION SET SORT_AREA_SIZE = 65536;
ALTER SESSION SET HASH_AREA_SIZE = 65536;