108 SGA详解及相关的查看命令

一、Instance:数据库启动后在内存中的映像,以及管理该内存区的后台进程;
组成:(SGA+background process);
查看数据库的实例名:
Sql >show parameter instance name;
查看数据库名:
Show parameter db_name;
数据库的文件组成:参数文件(spfile,pfile..),控制文件(controlfile),日志文件(redofile..),口令文件(v$pwfile_users),数据文件,跟踪文件(.trace),警告文件(alert),归档文件(achivlog);

二、实例与数据库的关系:
一个实例对应一个数据库:单点数据库(通常情况)
多个实例对应一个数控库:OPS和RAC(多个SGA)
前期的并行服务器:Oracle Paraller Server
应用集群 :Real Application Cluster

      SGA(system global area)  SGA是一组包含着一个oracle实例的数据和控制信息的共享内存结构
     是为oracle系统分配的共享内存;
     是实例的主要组成部分,最影响数据库性能;
     自动动态管理各种缓冲(ASMM, keep,recycle,redo_log_buffer不参与动态分配)

三、SGA的缓存类型:
1. db_buffer_cache(数据缓存)
(1) default_pool (普通进程访问此缓冲区会将该缓存区移动到LRU列表的MRU端,但是执行FTS(full table scan)和 小表查询时会放到LRU端)
(2) keep pool (数据先进先出,用来放热点表,VIP池)
(3) recycle pool (用来放冷点大表,不需要多大空间,吸引冷数据。相当于垃圾池)
(4) db_nk_cache_size(不同内存块大小以适应不同块大小表空间)
2. shared_pool(SGA中最关键内存片段,太小降低性能,太大消耗大量cpu资源)
(1) library_cache(sql语句缓存)
(2) data dictionary cache(数据字典缓存)
(3) other(600多项部分)
3. large_pool (常用做备用池)
4. java_pool(java开发支持)
5. redo_log_buffer(记载对数据库的任何修改,写入磁盘的redolog是实例恢复的依据)

四、SGA部分重要查询命令:
1、设置自动跟踪统计:
Set autot on stat
Set autot off
Show sga
Select * from vsga Show parameter sga;(查看sga max size,sga target size大小,运行时是否将SGAs锁定到物理内存(lock sga),启动时是 否都使用物理内存(pre page sga); Show parametetr pre_page_sga; Show parameter lock_sga; Alter system set pre_page_sga=true scope=spfile alter system set sga_max_size=512M scope=spfile (重启生效) show parameter sga_max_size; show parameter sga_target; alter system set sga_target_size=400m scope=both (memory –a- s pfile) Granule_size: sga内存的颗粒度大小,手工分配内存大小,会自动调整为颗粒度的整数倍。 若SGA小于1G,granule_size=4m 若SGA大于1G granule-size=8m (for windows) granule-size=16m(fro other) SGA_TARGET (Automatic shared memory management ) 2、查看各缓存下限值: Show parameter db_cache_size; Show parameter shared_pool_size; Show parameter java_pool_size; Show parameter large_pool_size; 3、查看实际大小: Select name,current_size from vbuffer_pool;查看实际大小
Select pool,sum(bytes) from vsgastat group by pool;(查看java,shared,large pool size) 若需改小某缓冲区的分配下限值,需先关闭ASMM, 修改完后需将所有缓存下限修改回0 使ASMM能自动管理 4、查询当前各池的分配大小: Select component,current_size from vsga_dynamic_components ;
5、指定对象全表扫描时数据仍放在MRU端
Create table aaa() cache;
Altert table aaa cache;
6、修改keep,recycle池大小并指定对象使用
Alter system set db_keep_cache_size=10m scope=both
Alter system set db_recycle_cache_size=10m scope=both
Create table aaa() storage (buffer_pool keep/recycle)
Alter table bbb storage(buffer_pool keep/recycle)
7、创建非标准内存块大小(内存块不为8k),以建非标准大小块表空间
Show parameter db%cache_size;
Alter system set db_16k_cache_size=10m;
Create tablespace I datafile ‘/u01/i.dat’ size 50m blocksize 16k;
8、查看library cache大小
Select sum(sharable_mem) from vdb_object_cache 9、清空缓存区: Alter system flush shared_pool 10、设置计时: Set timing on; 11、查看保存在library cache中保存的已分析sql语句 Select * from vsqltext where sql_text like ‘%dba_object%’;
Select sql_text from vsqlarea where sql_text like ‘%dba_object%’; 12、数据字典: Select * from dict; 查看数据字典 13、查看数据库中有哪些用户: Select username from dba_users; 14、查看数据库中有哪些数据文件; Select file_name from dba_data_files; Select name from vdatafile;
15、查看数据字典缓存的大小
Select sum(sharable) from vsqlarea; 五、动态表: 1、查看系统中所有的动态表: Select * from vfixed_table;
Fixed SGA:shared pool 内的dictionary cache中的一部分与其他部分附加内存信息会被实例的后台进程所访问,在实例启动后会被固定在SGA中,是SGA中固定组件;

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。