设为首页 收藏本站
查看: 1427|回复: 0

[经验分享] OracleDBA之路之Oracle体系结构介绍(二)

[复制链接]
YunVN网友  发表于 2016-8-13 06:26:15 |阅读模式
  这次介绍Oracle的Memory Structure(内存块)
Oracle包含两大内存块
1:System Global Area(SGA)
SGA 主要有3个内存块 Shared Pool(共享池),Database Buffer Cache(数据缓存池),Redo Log Buffer(日志缓存池),还有2个 Large Pool,Java Pool
查看SGA的大小:
SQL> show sga;
SGA是一个可动态变化的内存块,它的最大值由SGA_MAX_SIZE来决定的。
  LOG_BUFFER它的大小由Redo Log Buffer来决定
  DB_CACHE_SIZE 它是固定的,如果是NT系统则是52M,如果是Unix系统则为 48M
  SHARED_POOL_SIZE,默认大小为16M,如果是64位则为64M
  JAVA_POOL 默认大小为24M
  LARGE_POOL_SIZE默认大小为0M
  granules 分配内存的基本单位
如果SGA的小于128M则 granules的大小为4M,否则为16M
在系统中查看granules的大小
select component,granule_size from v$sga_dynamic_components;
  -Shared Pool
主要用于存放解析好的sql语句及pl/sql语句
---Library Cache
用于存放解析好的sql语句及pl/sql语句,Oracle执行语句的时候先从Libray Cache中查找,如果找到则直接执行,如果没有则重新解析并执行
---Data Dictionary Cache
用户存放数据字典的,信息包括 用户信息,数据文件名称等
修改大小使用下面的命令即可,但是它的最大值不能超过SGA_MAX_SIZE 
alter system set shared_pool_size=64M
  -Database buffer cache
存储真正的数据,包含来自数据库文件的数据及即将写到数据库文件的数据,Oracle查询时先从Database buffer cache中找数据,如果没有则到磁盘中查找。主要作用就是提高性能。
Oracle是按块来存储的(DB_BLOCK_SIZE)
---DB_CACHE_SIZE
不允许设置为0,
---DB_KEEP_CACHE_SIZE
---DB_RECYCLE_CACHE_SIZE
修改大小
alter system set db_cache_size=94M;
  -Redo Log Buffer
可恢复的操作有insert,update,delete,create,alter,drop
每对数据进行一次改变,在redo 中就记录一条 为redo entries
一条redo记录可以恢复一次对数据库的改变
  Large Pool
共享服务器会话内存
IO服务器进程
备份和恢复操作
并行执行等
  在备份及恢复时如果BACKUP_DISK_IO=n 并且 BACKUP_TAPE_IO_SLAVE=TRUE时,Large Pool将被使用
大小由参数 LARGE_POOL_SIZE决定,不是动态参数
JAVA POOL
JAVA POOL并不是必须的,如果你的安装并使用java的话,它将被使用,在9i中大小为24M
  
2:Program Global Area(PGA)
连接到Oralce数据库的每个用户进程保留到内存创建进程的时候分配,终止进程的时候销毁,一个进程只能有一个pga

运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-256900-1-1.html 上篇帖子: Excel向oracle表中导入数据(SQL Loader) 下篇帖子: Java连接访问Oracle--Connection.setSavepoint()方法使用
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表