体系结构和备份恢复原理
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相关信息见 专题页面