文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

oracle中SGA区基础知识与查看命令的示例分析

2023-06-06 02:13

关注

这篇文章将为大家详细讲解有关oracle中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部分重要查询命令:

设置自动跟踪统计:

Set autot on stat

Set autot off

Show sga

Select * from v$sga

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 )

查看各缓存下限值:

Show parameter db_cache_size;

Show parameter shared_pool_size;

Show parameter java_pool_size;

Show parameter large_pool_size;

查看实际大小:

Select  name,current_size from v$buffer_pool;

Select pool,sum(bytes) from v$sgastat group by pool;(查看java,shared,large pool size)

若需改小某缓冲区的分配下限值,需先关闭ASMM, 修改完后需将所有缓存下限修改回0 使ASMM能自动管理

查询当前各池的分配大小:

 Select component,current_size from v$sga_dynamic_components ;

指定对象全表扫描时数据仍放在MRU端

  Create table aaa() cache;

 Altert table aaa cache;

修改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)

创建非标准内存块大小(内存块不为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;

查看library cache大小

Select sum(sharable_mem) from v$db_object_cache

清空缓存区:

 Alter system flush shared_pool

设置计时:

Set timing on;

查看保存在library cache中保存的已分析sql语句

Select * from  v$sqltext where sql_text like ‘%dba_object%’;

Select  sql_text from v$sqlarea where sql_text like ‘%dba_object%’;

数据字典:

Select * from dict; 查看数据字典

查看数据库中有哪些用户:

Select username from dba_users;

查看数据库中有哪些数据文件;

Select file_name from dba_data_files;

Select name from v$datafile;

查看数据字典缓存的大小

Select sum(sharable) from v$sqlarea;

动态表:

查看系统中所有的动态表:

Select * from v$fixed_table;

Fixed SGA:shared pool 内的dictionary cache中的一部分与其他部分附加内存信息会被实例的后台进程所访问,在实例启动后会被固定在SGA中,是SGA中固定组件;

关于“oracle中SGA区基础知识与查看命令的示例分析”这篇文章就分享到这里了,希望以上内容可以对大家有一定的帮助,使各位可以学到更多知识,如果觉得文章不错,请把它分享出去让更多的人看到。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯