oracle12c体系结构,oracle 第一篇: oracle12c体系结构

1、oracle12c的体系结构:

内存(逻辑)结构:

SGA可以分为数据缓冲区、日志缓冲区、共享池、大型池、JAVA池、流池。

数据缓冲区(data buffer cache):oracle读取数据的缓存区,执行数据的临时存储空间以及修改未提交时,未写入磁盘的脏数据。主要作用是提高数据的查询速度和减少磁盘的I/O操作;

日志缓冲区(redo log buffer cache):在执行sql语句之前,需要计算出sql执行语句的改变向量,并将该向量以日志的形式临时存储在该内存区域,然后再去数据缓冲区进行数据的更改。

共享池(share pool):共享池分为库缓存、数据字典缓存、sql查询和pl/sql函数结果查询缓存;共享池的大小9i版本之后就可以直接调整大小。

3eaa1bb96a61da34c3a488e842bd844e.png库缓存:用于临时存储近期已经分过的代码,再次使用时就不需要对该代码进行分析,直接调用。提高语法的执行效率。

169503b73eba6378c7ee5557361ca915.png数据字典缓存:用于对近期调用的数据字典进行缓存,并且数据字典缓存的分配是在库缓存之后的,所以只要库缓存没问题,数据字 典缓存也就没问题。

8aaad62e24c40a423fe2e70ec442b47f.pngsql查询和pl/sql函数结果查询缓存:当同一会话或者多个不同的会话执行多次,就会将该查询的结果存储在内存中,当下一次查询时直接去调用该查询的结果。在运用该执行结果之前缓存机制会自动的检查查询中的表等对象是否发生了变化。如果变化就会重新查询,使用重新查询得到的结果。

大型池(large pool):可选择型的内存区域,主要用于共享服务器进程的使用。如果未分配再用刀该内存时会在共享池中进行分配。

JAVA池(java pool):在运行java过程时才使用到java池,它作用于java对象所需要的堆空间。但是实际java的实际运行还是在数据缓存区。

流池(stream pool):用于在redo log中获取日志向量,并重新构造执行语句,在远程数据库执行。而在redo log中提取更改的进程以及应用更改的进程将用到内存,该内存即是流池。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值