Oracle 物理体系
Oracle 物理体系
- Oracle 物理体系
- 问题
- 参考资料
Oracle 物理体系
PGA:program global area ,私有不共享内存。
PGA起到预处理的作用:
1.保存用户的连接信息,如session属性,绑定变量等;
2.保存用户权限等重要信息;
3.需要排序时,PGA就是排序区;
SGA:system global area,共享内存。
SGA由下组成:
1.共享池
2.数据缓冲区
3.日志缓冲区
后台进程:
1.PMON:process monitor 进程监视器
2.SMON:system monitor 系统监视器
3.DBWR:database writer 将数据缓冲区的数据刷到磁盘数据文件中
4.LGWR:log writer 将日志缓冲区的数据刷到磁盘日志文件中
5.CKPT:checkoutPoint 触发DBWR,批量将数据缓冲区的数据刷到磁盘中。并非是commit操作触发DBWR,因为批量操作比单次操作效率高。
6.ARCH 归档日志文件
……
数据库:
1.数据文件
2.参数文件
3.控制文件
4.日志文件
SGA+后台进程 = 数据库实例;
Oracle服务 = 实例(内存+进程)+ 数据库(磁盘文件);
在多实例数据库环境下,实例和数据库是多对一的关系,但是在大部分情况下是一对一。
SQL语句在物理体系中的流转过程:
1.SQL进入PGA进行预处理。保存连接信息,权限信息。如果有排序指令,则进行排序,PGA就是排序区。若内存不够,超出的部分需要到临时表空间中进行排序,即在磁盘中完成排序。只要session不断开连接,下次系统不需要再到磁盘中读取相关的连接信息和权限信息,直接从PGA内存空间中获取。
2.SQL匹配一条唯一的HASH值,进入SGA进行处理。先在共享池中查询是否有存储该HASH值,若有,则跳过语法语义检查、权限检查、解析,直接获得执行计划。若无,则先进行语法语义检查,权限检查,没有问题的话生成该条SQL的唯一HASH值并保存下来。然后进行解析,解析该SQL执行计划。完成解析后将执行计划保存起来,并和HASH值对应起来。
3.SQL进入数据缓冲区,检查是否有需要的数据,若无,则按照执行计划到磁盘数据库文件中查找,找到了就带着数据返回到数据缓冲区。
4如果SQL语句是查询语句,则到第三步,即完成了SQL语句。如果是更新语句,则要遵循 “日志现行” “凡事有记录”的原则,记录日志,并且要保存数据的前镜像。然后才进行更新操作。
Tips:
1.因为Oracle有缓存的功能,如果有缓存SQL相应的连接信息,权限信息,执行计划,数据等,不用去磁盘上读取,可以减少物理读。所以执行相同的SQL,第二次比第一次快。
2.如果PGA内存分配太小,排序量太大,部分排序需要到磁盘上进行,IO操作增多,会降低性能。
3.commit不能触发DBWR,而是CKPT触发,是因为批量操作效率优于单次操作。
4.保存数据前镜像,可以实现回滚和数据的一致读。
问题
1.Oracle为什么要有归档日志文件的操作,为什么不直接将日志缓冲区中的日志信息保存到归档文件中。
2.没有commit,DBWR也会将数据刷到磁盘数据库文件中?
参考资料
“收获,不止Oracle”
Oracle 物理体系的更多相关文章
- Oracle 10g体系机构及安全管理《思维导图》
通过学习Oracle数据库后,我对数据库又有了进一步的了解,Oracle数据库 10g体系机构分为 物理和逻辑存储结构. 下面是我对Oracle数据库做的思维导图和笔记 (全屏查看:<思维导图& ...
- Oracle 逻辑体系
Oracle 逻辑体系 主题 Oracle 逻辑体系 参考资料 Oracle 逻辑体系 表空间.模式.用户.段.区.块 Oracle中的数据逻辑上存储于表空间,物理上则存储于属于表空间tabl ...
- Oracle物理体系结构
一.ORACLE 物理体系结构 原理结构图 各部分解释: PGA: 私有内存区,仅供当前发起用户使用. 三个作用 用户登录后的session信息会保存在PGA. 执行排序,如果内存不够,oracle会 ...
- Oracle 物理备份--rman
Oracle 物理备份--rman 1.直接在服务器,打开命令行,输入: rman target/ 2.配置参数也一同备份 configure controlfile autobackup on; 如 ...
- [转帖]Oracle 补丁体系(PSR/PSU/CPU) 及 opatch 工具 介绍
Oracle 补丁体系(PSR/PSU/CPU) 及 opatch 工具 介绍 原文:http://blog.csdn.net/tianlesoftware/article/details/58095 ...
- Oracle物理的体系结构
体系结构图的学习: 老余服装店的故事 结构图: SQL查询语句 SGA 共享池shared pool 数据缓存区Buffer cache PGA 进程 SQL更新语句 SGA: 日志缓存区 日志文件 ...
- ORACLE 物理读 逻辑读 一致性读 当前模式读总结浅析
在ORACLE数据库中有物理读(Physical Reads).逻辑读(Logical Reads).一致性读(Consistant Get).当前模式读(DB Block Gets)等诸多概念,如果 ...
- 浅谈Oracle权限体系
对于数据库来讲,安全性的重要程度不言而喻,今天我们就来聊一聊Oracle的权限体系. 1.账户管理 在此之前,先解释下一个容易混淆的概念:模式.所谓模式,指的是用户账户所拥有的一组对象(比如表,索引, ...
- oracle物理视图(转)
近期根据项目业务需要对oracle的物化视图有所接触,在网上搜寻关于这方面的资料,便于提高,整理内容如下: 物化视图是一种特殊的物理表,“物化”(Materialized)视图是相对普通视图而言的.普 ...
随机推荐
- ubuntu挂载3T新硬盘并更换home分区
ubuntu添加一块新的硬盘,并更换home分区 1.将硬盘接入机箱,开机,查看是否现有的硬盘信息 从这里可以看出,共有两块硬盘,分别是sda和sdb 2.执行fdisk -l,确保我们要添加的就是s ...
- windows系统下GCC的安装与配置
刚开始看 C++ Primer,看到编译器的部分,自己搜了搜怎么搭建GCC,搜到以下内容,复制过来留个印象: windows系统下GCC的安装方法,以及一些环境变量的配置,如果对GCC不是很清楚,关于 ...
- 获取取并下载tuku的漫画的爬虫
代码地址如下:http://www.demodashi.com/demo/12842.html 概述 一个简单的爬虫,实现是爬取tuku网站的漫画.并下载到脚本的文件夹中,下载的漫画按照章节名放在各自 ...
- PLSQL中scott账户登录不上,报错ORA-01017: invalid username/password; logon denied
问题:PLSQL中scott账户登录不上,提示上述错误 解决方法: 1. cmd——>进入c目录; 2. 输入:sqlplus/nolog; 3. connect username/passwo ...
- Linux中如何配置IP
与网络相关的文件:1) /etc/sysconfig/network 设置主机名称及能否启动Network2) /etc/sysconfig/network-scripts/ifcfg-eth ...
- 自己动手制作更好用的markdown编辑器-02
这里文章都是从个人的github博客直接复制过来的,排版可能有点乱. 原始地址 http://benq.im 文章目录 1. 工具条 1.1. 样式 1.2. 工具条截图 2. 状态栏消息 3. 文件 ...
- Mysql 没有nvl()函数,却有一个类似功能的函数ifnull()
今天自己无聊写了看了一个查询需求随手写了一个sql语句,发现竟然不能运行,MySQL报[Err] 1305 - FUNCTION ceshi.nvl does not exist的错.才意识到自己写的 ...
- Creating Context Menu / 创建上下文菜单项 / VC++, Windows, DLL, ATL, COM
创建上下文菜单项 1.新建一个ATL Project. 2.建议将Project Property中Linker – General - “Register Output” 设为no,C/C++ - ...
- class文件简介及加载
Java编译器编译好Java文件之后,产生.class 文件在磁盘中.这种class文件是二进制文件,内容是只有JVM虚拟机能够识别的机器码.JVM虚拟机读取字节码文件,取出二进制数据,加载到内存中, ...
- SecureCRT中的vim出现1H特殊字符
问题原因:由于采用了UTF_8编码方式导致的. 解决方法:把字符编码改为:GB18030即可.如图: