oracle架构简介

Oracle数据库架构简单来说如下图:

1、客户端链接数据库实例有两种模式:一是独占模式及一个回话一个server process;二是共享及有中间代理层,相当于增加了一层代理分发。

2、以独占模式举例,一个客户端发起一条SQL,这个SQL由server process进程接受,server process 也有内存叫PGA,然后到SGA里面去找这条SQL是否有相同的,如果有,就用相同的SQL的执行计划,这个叫软解析。如果没有就需要经过解析、优化得到执行计划,这是比较耗时的,称为硬解析。解析完后需要查询数据,这时就到了database buffer cache里去找是否有数据,如果有就直接返回;如果没有就需要server process进程触发DBWR后台进程从磁盘里读数据块到database buffer cache里。如果SQL是delete、update、insert改变数据块了,这个时候会有日志,这个日志先是写到PGA里,然后再写到redo log cache里,由LGWR将redo log cache里的数据顺序写到redo log文件中(触发条件有commit、每3秒、redo log cache占了1/3以上、日志切换、DBWR刷脏块落盘时)

相关推荐
廿一夏7 小时前
MySql存储引擎与索引
数据库·sql·mysql
lzhdim9 小时前
SQL 入门 15:SQL 事务:从 ACID 到四种常见的并发问题
数据库·sql
瀚高PG实验室9 小时前
瀚高企业版V9.1.1在pg_restore还原备份文件时提示extract函数语法问题
数据库·瀚高数据库
TDengine (老段)10 小时前
TDengine Tag 设计哲学与 Schema 变更机制
大数据·数据库·物联网·时序数据库·iot·tdengine·涛思数据
YOU OU11 小时前
Spring IoC&DI
java·数据库·spring
Muscleheng11 小时前
Navicat连接postgresql时出现‘datlastsysoid does not exist‘报错
数据库·postgresql
罗超驿12 小时前
18.事务的隔离性和隔离级别:MySQL面试高频考点全解析
数据库·mysql·面试
jran-12 小时前
Redis 命令
数据库·redis·缓存
小江的记录本13 小时前
【Java基础】Java 8-21新特性:JDK21 LTS:虚拟线程、模式匹配switch、结构化并发、序列集合(附《思维导图》+《面试高频考点清单》)
java·数据库·python·mysql·spring·面试·maven
June`13 小时前
多线程redis下如何解决aof重写和rdb持久化的数据一致性问题
数据库·redis·缓存