当前位置:  数据库>oracle

Oracle体系结构学习笔记

    来源: 互联网  发布时间:2017-04-28

    本文导语: 体系结构和备份恢复原理1 Oracle database 最重要的是online redo log  类比法  controlfile    :公司高管  datafile       :生产车间  online redo log:财务处  注释:  system表空间是第一生产车间;  当公司高管换了,财务处也需要换...

体系结构和备份恢复原理
1 Oracle database 最重要的是online redo log
  类比法
  controlfile    :公司高管
  datafile       :生产车间
  online redo log:财务处
  注释:
  system表空间是第一生产车间;
  当公司高管换了,财务处也需要换;







2 shared pool主要包括:
  library cache:放代码(sql,pl/sql,java)
  data dictionary cache:放数据字典
  注释:
  在空间分配上,数据字典是男孩,代码是女孩,oracle server有重男轻女思想,若cache命中率低,要看的是女孩,而非男孩。因为会先给男孩喂奶水。
  最近最少使用到代码会被销隐掉,否则,不断的代码进来,shared pool会内存不足。




3 large pool
  下列场景需要用到large pool:
   用rman备份与恢复;
   并行sql;
   异步I/O;
   共享服务器模式;
   注释:
   large pool是shared pool的助理,若没有large pool,则会池迁移到shared pool。






4 java pool
  是个跑马场,不是放java代码的地方

5 database buffer cache和redo log buffer
  1)二者关系:
 redo log buffer         画家(描述者)
 database buffer cache   模特(被描述者)
  2)LGWR只能有一个;DBWR可以有多个
  3)oracle爱写日志,不爱写数据块。因为日志的单位是项(200个字节左右),而数据块的单位是块。
  4)redo log buffer要么全写,要么全不写;而database buffer cache则悠着点,一次写一点
  5)什么时候写日志?
  每3秒写
 1/3满写
 commit的时候写
 n M脏数据的时候写
 DBWR写之前写
  6)什么时候写数据块?
 完全检查点事件发生
 超时发生(增量检查点)
 脏块达到域值(增量检查点)
 没有free buffer的时候(对上面一条到补充)
















6 oracle是个交易系统,其交易发生在database buffer cache里。
  具体交易:
  “读”:server process去data dictionary cache查询,将需要的读到database buffer cache,然后,在PGA构造游标(结果集的指针),每一根指针都指向一个rowid,如果需要排序,连接,一致性读,则只需要对指针进行操作。所以,PGA是用户最直接的使用体验。
  “改”:  申请TADDR
   记日志
   动两边事务槽,加行头锁
  “写”:检查点进程计算工作负载,来定检查点,在检查点时,发生检查点事件,当检查点事件发生时逼着DBWRn按块第一次变脏的顺序写出一部份,由于这一部分脏块的写出,会在日志文件产生检查点位置。





7 RBA指针后有日志项,原因有二:
  1)整个表空间级下线
  2)按块第一次变脏的顺序写

8 用户不直接和oracle server打交道,而是和server process扛上了。
  类比:
  server process      导购小姐
  user   process      客人


9 “一根骨头挂点肉”
  这俗语可以形容server process 和PGA的关系
  骨头:server process
  肉  :PGA
  “一条绳上的两个蚂蚱”
  蚂蚱:SADDR,TADDR
  这话是说,新值在写的时候,旧值会跟着被写,同呼吸,共命运。所以,读上来8k,写下去便是16k,总共I/O为24k。





10 透过现象看本质
   提交的本质:释放锁,写日志,事务槽进入倒计时
   正常关机的本质:
     1)关闭JAVA进程(oracle大战java)
     2)写检查点
 a)将current_scn冻结
        b)把data block写下
 c)让checkpoint_change#等于current_scn
   注释:
   select resetlogs_change# a,checkpoint_change# b,current_scn c
   from v$database
   其中,aC
   这时,就需要派SMON去前滚,按重做日志的记录在内存中重做一遍,直到C=D。






更多Oracle相关信息见 专题页面


    
 
 
 
本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • Oracle物理结构概述
  • 轻松理解Oracle数据库中的物理结构
  • ORACLE 修改表结构 之ALTER CONSTAINTS的使用
  • oracle复制表结构和复制表数据语句分享
  • 手把手教你Oracle数据库导出数据库结构到PowerDesigner
  • oracle 数据库学习 基本结构介绍
  • Oracle网络应用结构
  • Oracle专用服务器的内存结构分布原则
  • 在Oracle网络结构解决连接问题
  • Oracle 11g Release (11.1) 索引底层的数据结构
  • Oracle 12c发布简单介绍及官方下载地址
  • Oracle物理结构概述 iis7站长之家
  • oracle 11g最新版官方下载地址
  • 请问su oracle 和su - oracle有什么不同?
  • Oracle 数据库(oracle Database)Select 多表关联查询方式
  • 虚拟机装Oracle R12与Oracle10g
  • 如何设置让Oracle SQL Developer显示的时间包含时分秒
  • Oracle 数据库开发工具 Oracle SQL Developer
  • Oracle 10g和Oracle 11g网格技术介绍
  • Oracle EBS R12 支持 Oracle Database 11g
  • oracle中如何把表中具有相同值列的多行数据合并成一行
  • SCO unix下安装oracle,但没有光盘,请大家推荐一个oracle下载站点(unix版本的)。谢谢!!!!
  • Oracle 数据库(oracle Database)性能调优技术详解
  • 请问大家用oracle数据库, 用import oracle.*;下的东西么? 还是用标准库?
  • ORACLE日期相关操作
  • Linux /$ORACLE_HOME $ORACLE_HOME
  • ORACLE数据库常用字段数据类型介绍
  • Linux系统下Oracle的启动与Oracle监听的启动
  • Oracle 12c的九大最新技术特性介绍
  • 请问在solaris下安装ORACLE,用root用户和用oracle用户安装有什么区别么?
  • ORACLE中DBMS_RANDOM随机数生成包


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,