首頁 資料庫 mysql教程 Oracle体系结构学习笔记

Oracle体系结构学习笔记

Jun 07, 2016 pm 05:14 PM
資料庫

Oracle体系结构学习笔记,oracle database 最重要的是online redo log,ldquo;写rdquo;:检查点进程计算工作负载,来定检查点,

体系结构和备份恢复原理
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
   其中,a   a:建库的时间原点
   b:写数据块的界,写后,内存中的所有数据块多比b来得大。所以,增量检查点这个会被延迟标识,因为,还没有全部下来。

11 system表空间
   1)存放数据字典表
   2)包,过程,函数和触发器等pl/sql对象

12 sysaux表空间
   1)90%用来收集工作负载
   2)10%存放sysman到东西
   类比:
   生活中,水表,电表,煤气表,这些表上面的度数,都是“逝者如斯夫”,为了比较,合理开支,需要抄表。

13 buffer的四种状态
   free:写下去的时候
   clean:刚读上来
   pinned:特殊的clean,被加了latch,正要用
   dirty:被改了

14 RBA指针的碎碎念
   方向:总是无缝下移
   出生地:控制文件
   指向地:日志文件
   过帐:对应的数据块已写到数据文件中
   active :被RBA覆盖的日志(RBA只有一根)
   完全检查点会直接把RBA干到重做日志组的最后一条

15 断电本质:SGA突然没有了,实力崩溃
   与断电本质一致的是:
   干掉SMON进程(kill -9 PID)
   shutdown abort

16 在mount阶段,由SMON去读控制文件,并比较:
   1)上次关机的SCN             A
      上次关机的checkpoint      B
   2)日志组最后一条的记录       C
      RBA指针的位置             D
   若正常关机,则 A=B C=D
   若不正常关机,则 A>B  D>C
   这时,就需要派SMON去前滚,按重做日志的记录在内存中重做一遍,直到C=D。

更多Oracle相关信息见Oracle 专题页面 ?tid=12

linux

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱門文章

<🎜>:泡泡膠模擬器無窮大 - 如何獲取和使用皇家鑰匙
3 週前 By 尊渡假赌尊渡假赌尊渡假赌
北端:融合系統,解釋
4 週前 By 尊渡假赌尊渡假赌尊渡假赌
Mandragora:巫婆樹的耳語 - 如何解鎖抓鉤
3 週前 By 尊渡假赌尊渡假赌尊渡假赌

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

熱門話題

Java教學
1670
14
CakePHP 教程
1428
52
Laravel 教程
1329
25
PHP教程
1273
29
C# 教程
1256
24
iOS 18 新增「已復原」相簿功能 可找回遺失或損壞的照片 iOS 18 新增「已復原」相簿功能 可找回遺失或損壞的照片 Jul 18, 2024 am 05:48 AM

蘋果公司最新發布的iOS18、iPadOS18以及macOSSequoia系統為Photos應用程式增添了一項重要功能,旨在幫助用戶輕鬆恢復因各種原因遺失或損壞的照片和影片。這項新功能在Photos應用的"工具"部分引入了一個名為"已恢復"的相冊,當用戶設備中存在未納入其照片庫的圖片或影片時,該相冊將自動顯示。 "已恢復"相簿的出現為因資料庫損壞、相機應用未正確保存至照片庫或第三方應用管理照片庫時照片和視頻丟失提供了解決方案。使用者只需簡單幾步

Hibernate 如何實作多型映射? Hibernate 如何實作多型映射? Apr 17, 2024 pm 12:09 PM

Hibernate多態映射可映射繼承類別到資料庫,提供以下映射類型:joined-subclass:為子類別建立單獨表,包含父類別所有欄位。 table-per-class:為子類別建立單獨資料表,僅包含子類別特有列。 union-subclass:類似joined-subclass,但父類別表聯合所有子類別列。

如何在PHP中處理資料庫連線錯誤 如何在PHP中處理資料庫連線錯誤 Jun 05, 2024 pm 02:16 PM

PHP處理資料庫連線報錯,可以使用下列步驟:使用mysqli_connect_errno()取得錯誤代碼。使用mysqli_connect_error()取得錯誤訊息。透過擷取並記錄這些錯誤訊息,可以輕鬆識別並解決資料庫連接問題,確保應用程式的順暢運作。

在PHP中使用MySQLi建立資料庫連線的詳盡教學 在PHP中使用MySQLi建立資料庫連線的詳盡教學 Jun 04, 2024 pm 01:42 PM

如何在PHP中使用MySQLi建立資料庫連線:包含MySQLi擴充(require_once)建立連線函數(functionconnect_to_db)呼叫連線函數($conn=connect_to_db())執行查詢($result=$conn->query())關閉連線( $conn->close())

如何在 Golang 中將 JSON 資料保存到資料庫中? 如何在 Golang 中將 JSON 資料保存到資料庫中? Jun 06, 2024 am 11:24 AM

可以透過使用gjson函式庫或json.Unmarshal函數將JSON資料儲存到MySQL資料庫中。 gjson函式庫提供了方便的方法來解析JSON字段,而json.Unmarshal函數需要一個目標類型指標來解組JSON資料。這兩種方法都需要準備SQL語句和執行插入操作來將資料持久化到資料庫中。

如何在 Golang 中使用資料庫回呼函數? 如何在 Golang 中使用資料庫回呼函數? Jun 03, 2024 pm 02:20 PM

在Golang中使用資料庫回呼函數可以實現:在指定資料庫操作完成後執行自訂程式碼。透過單獨的函數新增自訂行為,無需編寫額外程式碼。回調函數可用於插入、更新、刪除和查詢操作。必須使用sql.Exec、sql.QueryRow或sql.Query函數才能使用回呼函數。

mysql:簡單的概念,用於輕鬆學習 mysql:簡單的概念,用於輕鬆學習 Apr 10, 2025 am 09:29 AM

MySQL是一個開源的關係型數據庫管理系統。 1)創建數據庫和表:使用CREATEDATABASE和CREATETABLE命令。 2)基本操作:INSERT、UPDATE、DELETE和SELECT。 3)高級操作:JOIN、子查詢和事務處理。 4)調試技巧:檢查語法、數據類型和權限。 5)優化建議:使用索引、避免SELECT*和使用事務。

如何用 Golang 連接遠端資料庫? 如何用 Golang 連接遠端資料庫? Jun 01, 2024 pm 08:31 PM

透過Go標準庫database/sql包,可以連接到MySQL、PostgreSQL或SQLite等遠端資料庫:建立包含資料庫連接資訊的連接字串。使用sql.Open()函數開啟資料庫連線。執行SQL查詢和插入操作等資料庫操作。使用defer關閉資料庫連線以釋放資源。

See all articles