校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃

主頁 > 知識庫 > oracle 數據庫啟動階段分析

oracle 數據庫啟動階段分析

熱門標簽:400電話是不是免費申請 安陽外呼系統免費 貴陽電話外呼系統哪家好 濟南地圖標注公司 南寧人工智能電銷機器人費用 海南400電話哪里辦理 呼倫貝爾智能手機地圖標注 圖像地圖標注 分布式呼叫中心

Oracle Server主要由兩部分組成:Instance 和Database 。Instance 是指一組后臺進程/線程和一塊共享內存區域,而 Database是指存儲在磁盤上的一組物理文件。本文由數據庫 如何啟動入手。

數據庫的啟動

首先來分析一下數據庫的啟動過程,Oracle 數據庫的啟動主要包含 3 個步驟:

(1)啟動數據庫到 nomount 狀態;

(2)啟動數據庫到 mount 狀態;

(3)啟動數據庫到 open 狀態。

下面逐個來看看各個步驟的具體過程以其含義。

1. 啟動數據庫到nomount 狀態

在啟動的第一步驟,Oracle 首先尋找參數文件(pfile/spfile ),然后根據參數文件中 的設置,創建實例,分配內存,啟動后臺進程。

在這里可以看到,只要擁有了一個參數文件,就可以憑之啟動實例(Instance), 這一步 驟并不需要任何控制文件或數據文件的參與。

在創建數據庫時,如果在這一步驟就出現問題,那么通??赡苁窍到y配置(內核參數等)存在問題,用戶需要檢查是否分配了足夠的系統資源等。 來看一下啟動到 nomount 狀態的過程:

[oracle@dbtest dbs]$ cd $ORACLE_HOME/dbs
[oracle@dbtest dbs]$ ls
hc_orcl.dat init.ora initorcl.ora lkORCL orapworcl spfileorcl.ora
[oracle@dbtest dbs]$ sqlplus / as sysdba
SQL*Plus: Release 11.2.0.1.0 Production on Wed May 4 10:36:45 2016
Copyright (c) 1982, 2009, Oracle. All rights reserved.
Connected to an idle instance.
SQL> startup nomount;
ORACLE instance started.
Total System Global Area 1152450560 bytes
Fixed Size         2212696 bytes
Variable Size       922750120 bytes
Database Buffers     218103808 bytes
Redo Buffers        9383936 bytes
SQL>

注意這里,Oracle 根據參數文件的內容,創建了 instance ,分配了相應的內存區域,啟 動了相應的后臺進程。 此時觀察警報日志文件(alert_sid>.log ; show parameter dump查看路徑),可以看到這一階段的啟動過程,讀取參數 文件,應用參數啟動實例,所有在參數文件中定義的非缺省參數都會記錄在警報日志文件中:

Starting up:
Oracle Database 11g Enterprise Edition Release 11.2.0.1.0 - 64bit Production
With the Partitioning, OLAP, Data Mining and Real Application Testing options.
Using parameter settings in server-side spfile /u01/app/oracle/product/11.2.0/db_1/dbs/spfileorcl.ora
System parameters with non-default values:
 processes        = 150
 sga_target        = 176M
 memory_target      = 1104M
 memory_max_target    = 1104M
 control_files      = "/u01/app/oracle/oradata/orcl/control01.ctl"
 control_files      = "/u01/app/oracle/flash_recovery_area/orcl/control02.ctl"
 db_block_size      = 8192
 compatible        = "11.2.0.0.0"
 db_recovery_file_dest  = "/u01/app/oracle/flash_recovery_area"
 db_recovery_file_dest_size= 3882M
 undo_tablespace     = "UNDOTBS1"
 remote_login_passwordfile= "EXCLUSIVE"
 db_domain        = "oracle.com"
 global_names       = FALSE
 dispatchers       = "(PROTOCOL=TCP) (SERVICE=orclXDB)"
 shared_servers      = 5
 audit_file_dest     = "/u01/app/oracle/admin/orcl/adump"
 audit_trail       = "DB"
 db_name         = "orcl"
 open_cursors       = 300
 diagnostic_dest     = "/u01/app/oracle"

然后后臺進程依次啟動:

Wed May 04 10:36:55 2016
PMON started with pid=2, OS id=3128 
Wed May 04 10:36:55 2016
VKTM started with pid=3, OS id=3132 at elevated priority
VKTM running at (10)millisec precision with DBRM quantum (100)ms
Wed May 04 10:36:55 2016
GEN0 started with pid=4, OS id=3138 
Wed May 04 10:36:55 2016
DIAG started with pid=5, OS id=3142 
Wed May 04 10:36:55 2016
DBRM started with pid=6, OS id=3146 
Wed May 04 10:36:55 2016
PSP0 started with pid=7, OS id=3150 
Wed May 04 10:36:55 2016
DIA0 started with pid=8, OS id=3158 
Wed May 04 10:36:55 2016
MMAN started with pid=9, OS id=3162 
Wed May 04 10:36:55 2016
DBW0 started with pid=10, OS id=3166 
Wed May 04 10:36:55 2016
LGWR started with pid=11, OS id=3170 
Wed May 04 10:36:55 2016
CKPT started with pid=12, OS id=3175 
Wed May 04 10:36:55 2016
SMON started with pid=13, OS id=3179 
Wed May 04 10:36:55 2016
RECO started with pid=14, OS id=3184 
Wed May 04 10:36:55 2016
MMON started with pid=15, OS id=3189 
starting up 1 dispatcher(s) for network address '(ADDRESS=(PARTIAL=YES)(PROTOCOL=TCP))'...
Wed May 04 10:36:55 2016
MMNL started with pid=16, OS id=3193 
starting up 5 shared server(s) ...
ORACLE_BASE from environment = /u01/app/oracle

這里注意一下 Oracle選擇參數文件的順序:

Oracle 首選spfilesid>.ora文件作為啟動參數文件;如果該文件不 存在,Oracle選擇spfile.ora 文件;如果前兩者都不存在,Oracle將會選擇 initsid>.ora文件;如果以上 3 個文件都不存在,Oracle 將無法創建和啟動 instance ,Oracle將無法啟動。

用戶可以在SQL*PLUS 中通過show parameter spfile 命令來檢查數據庫是否使用了 spfile文件,如果 value 不為Null,則數據庫使用了 spfile文件:

SQL> show parameter spfile

NAME                 TYPE    VALUE
------------------------------------ ----------- ------------------------------
spfile                string   /u01/app/oracle/product/11.2.0
                         /db_1/dbs/spfileorcl.ora
SQL>

這時候也可以從操作系統查看啟動了的后臺進:

[root@dbtest trace]# ps -ef|grep ora_ 
oracle  3128   1 0 10:36 ?    00:00:00 ora_pmon_orcl
oracle  3132   1 0 10:36 ?    00:00:00 ora_vktm_orcl
oracle  3138   1 0 10:36 ?    00:00:00 ora_gen0_orcl
oracle  3142   1 0 10:36 ?    00:00:00 ora_diag_orcl
oracle  3146   1 0 10:36 ?    00:00:00 ora_dbrm_orcl
oracle  3150   1 0 10:36 ?    00:00:00 ora_psp0_orcl
oracle  3158   1 0 10:36 ?    00:00:00 ora_dia0_orcl
oracle  3162   1 0 10:36 ?    00:00:00 ora_mman_orcl
oracle  3166   1 0 10:36 ?    00:00:00 ora_dbw0_orcl
oracle  3170   1 0 10:36 ?    00:00:00 ora_lgwr_orcl
oracle  3175   1 0 10:36 ?    00:00:00 ora_ckpt_orcl
oracle  3179   1 0 10:36 ?    00:00:00 ora_smon_orcl
oracle  3184   1 0 10:36 ?    00:00:00 ora_reco_orcl
oracle  3189   1 0 10:36 ?    00:00:00 ora_mmon_orcl
oracle  3193   1 0 10:36 ?    00:00:00 ora_mmnl_orcl
oracle  3197   1 0 10:36 ?    00:00:00 ora_d000_orcl
oracle  3201   1 0 10:36 ?    00:00:00 ora_s000_orcl
oracle  3205   1 0 10:36 ?    00:00:00 ora_s001_orcl
oracle  3209   1 0 10:36 ?    00:00:00 ora_s002_orcl
oracle  3213   1 0 10:36 ?    00:00:00 ora_s003_orcl
oracle  3217   1 0 10:36 ?    00:00:00 ora_s004_orcl
root   3358 3253 0 10:50 pts/3  00:00:00 grep ora_

如果這3 個文件都不存在,Oracle 將無法啟動:

[oracle@dbtest dbs]$ mv init.ora init.ora.bak
[oracle@dbtest dbs]$ mv initorcl.ora initorcl.ora.bak
[oracle@dbtest dbs]$ mv spfileorcl.ora spfileorcl.ora.bak
[oracle@dbtest dbs]$ ls
hc_orcl.dat init.ora.bak initorcl.ora.bak lkORCL orapworcl spfileorcl.ora.bak
[oracle@dbtest dbs]$ sqlplus / as sysdba
SQL*Plus: Release 11.2.0.1.0 Production on Wed May 4 10:55:42 2016
Copyright (c) 1982, 2009, Oracle. All rights reserved.
Connected to an idle instance.
SQL> startup nomount;
ORA-01078: failure in processing system parameters
LRM-00109: could not open parameter file '/u01/app/oracle/product/11.2.0/db_1/dbs/initorcl.ora'

在Oracle整個啟動過程中,參數文件是寫在應用程序中的硬代碼,按照如上順序進行查 找,不能改變Oracle的搜索路徑及行為,但是如果參數文件不在相應的位置,在Linux/UNIX 系統上,可以通過符號鏈接來進行重定位。

在參數文件中,通常需要最少的參數是 db_name,設置了這個參數之后,數據庫實例就可以啟動,來看一個簡單的測試:

SQL> ! echo "db_name=julia" > initorcl.ora
SQL> startup nomount;
ORACLE instance started.
Total System Global Area 217157632 bytes
Fixed Size         2211928 bytes
Variable Size       159387560 bytes
Database Buffers      50331648 bytes
Redo Buffers        5226496 bytes

這樣,就通過了最少的參數需求啟動了 Oracle實例。

2. 啟動數據庫到mount 狀態

啟動到nomount 狀態以后,Oracle就可以從參數文件中獲得控制文件的位置信息, 這一部分信息在參數文件中的記錄類似如下所示(Oracle缺省會創建3 個控制文件,這 3 個控制文件的內容完全一致,是Oracle為了安全而采用的鏡像手段,在生產環境中,通 常應該將3 個控制文件存放在不同的物理硬盤上,避免因為介質故障而同時損壞3 個控制 文件):

SQL> show parameter control_files

NAME                 TYPE    VALUE
------------------------------------ ----------- ------------------------------
control_files            string   /u01/app/oracle/product/11.2.0
                         /db_1/dbs/cntrlorcl.dbf

在nomount 狀態,可以查詢v$parameter視圖,獲得控制文件信息,這部分信息來自啟 動的參數文件;當數據庫 mount 之后,可以查詢 v$controlfile視圖獲得關于控制文件的信 息,此時,這部分信息來自控制文件:

[oracle@dbtest dbs]$ mv init.ora.bak init.ora
[oracle@dbtest dbs]$ mv initorcl.ora.bak initorcl.ora
[oracle@dbtest dbs]$ mv spfileorcl.ora.bak spfileorcl.ora
[oracle@dbtest dbs]$ sqlplus / as sysdba

SQL*Plus: Release 11.2.0.1.0 Production on Wed May 4 11:07:07 2016
Copyright (c) 1982, 2009, Oracle. All rights reserved.
Connected to an idle instance.
SQL> startup nomount;
ORACLE instance started.
Total System Global Area 1152450560 bytes
Fixed Size         2212696 bytes
Variable Size       922750120 bytes
Database Buffers     218103808 bytes
Redo Buffers        9383936 bytes
SQL> alter database mount;  
Database altered.
SQL> select * from v$controlfile; 
STATUS
-------
NAME
--------------------------------------------------------------------------------
IS_ BLOCK_SIZE FILE_SIZE_BLKS
--- ---------- --------------
/u01/app/oracle/oradata/orcl/control01.ctl
NO    16384      594
/u01/app/oracle/flash_recovery_area/orcl/control02.ctl
NO    16384      594
STATUS
-------
NAME
--------------------------------------------------------------------------------
IS_ BLOCK_SIZE FILE_SIZE_BLKS
--- ---------- --------------

在mount 數據庫的過程中,Oracle需要找到控制文件并鎖定控制文件。如果控制文件全 部丟失此時就會報出如下錯誤:

SQL> alter database mount; 
alter database mount
*
ERROR at line 1:
ORA-00205: error in identifying control file, check alert log for more info

這時候alert.log 文件中通常會記錄更為詳細的信息。

因為Oracle的3 個(缺省的)控制文件內容完全相同,如果只是損失了其中 1~2 個, 可以復制完好的控制文件,更改為相應的名稱,就可以啟動數據庫;如果丟失了所有的控制 文件,那么就需要恢復或重建控制文件來打開數據庫。

在正常Mount 數據庫的過程中,數據庫的警報日志文件僅記錄如下信息:

alter database mount
Wed May 04 11:07:44 2016
Successful mount of redo thread 1, with mount id 1438756220
Database mounted in Exclusive Mode
Lost write protection disabled
Completed: alter database mount

在這一步驟中,數據庫需要計算Mount id 并將其記錄在控制文件中,然后開始啟動 Heartbeat(心跳),每3 秒更新一次控制文件。

啟動到Mount 狀態,數據庫必須具備的另外一個重要文件是口令文件,該文件位于 $ORACLE_HOME/dbs 目錄下,缺省的名稱為 orapw 。 口令文件中存放 sysdba/sysoper 用戶的用戶名及口令:

[oracle@dbtest dbs]$ strings orapworcl 
]\[Z
ORACLE Remote Password file
INTERNAL
769C0CD849F9B8B2
5638228DAF52805F
[oracle@dbtest dbs]$

在數據庫沒有啟動之前,數據庫內建用戶是無法通過數據庫本身來驗證身份的,通過口 令文件,Oracle 可以實現對用戶的身份認證,在數據庫未啟動之前登錄,進而啟動數據庫。 對于口令文件,Oracle 缺省查找 orapw 文件,如果該文件不存在,則繼續查找orapw 文件,如果兩者都不存在,則數據庫將會出現錯誤。

如果口令文件丟失,通過 orapw 工具即可重建,所以在通常的備份策略中可以不必包含 口令文件:

[oracle@dbtest dbs]$ orapwd
Usage: orapwd file=fname> entries=users> force=y/n> ignorecase=y/n> nosysdba=y/n>

 where
	file - name of password file (required),
	password - password for SYS will be prompted if not specified at command line,
	entries - maximum number of distinct DBA (optional),
	force - whether to overwrite existing file (optional),
	ignorecase - passwords are case-insensitive (optional),
	nosysdba - whether to shut out the SYSDBA logon (optional Database Vault only).
	
 There must be no spaces around the equal-to (=) character.
[oracle@dbtest dbs]$

通常在Linux/UNIX 平臺下,在$ORACLE_HOME/dbs 目錄下,還會存在另外一個文件,該文件命名規則為 lkSID>,lk指lock ,該文件在數據庫啟動時創建,用于操作系統對數據庫的鎖定。當數據庫啟動時獲得鎖定,數據庫關閉時釋放。該文件內容通常只有一行,提示不要刪除,該文件僅僅用于鎖定.

3. 啟動數據庫open階段

由于控制文件中記錄了數據庫中數據文件、日志文件的位置信息、檢查點信息等重要信 息,所以在數據庫的 open階段,Oracle可以根據控制文件中記錄的這些信息找到這些文件, 然后進行檢查點及完整性檢查。

如果不存在問題就可以啟動數據庫,如果存在不一致或文件丟失則需要進行恢復。

進一步地說,實際上在數據庫 open的過程中,Oracle 進行的檢查中包括以下兩項:

第一次檢查數據文件頭中的檢查點計數(Checkpoint cnt )是否和控制文件中的檢查點 計數(Checkpoint cnt )一致。此步驟檢查用以確認數據文件是來自同一版本,而不是從備 份中恢復而來(因為 Checkpoint Cnt 不會被凍結,會一直被修改)。 下面通過一個簡單的測試來說明一下 Checkpoint Cnt的作用。

如果檢查點計數檢查通過,則數據庫進行第二次檢查。第二次檢查數據文件頭的開始SCN 和控制文件中記錄的該文件的結束 SCN 是否一致,如果控制文件中記錄的結束 SCN 等于數據 文件頭的開始 SCN,則不需要對那個文件進行恢復。

總結

以上就是本文關于oracle 數據庫啟動階段分析的全部內容,希望對大家有所幫助。感興趣的朋友可以參閱:Oracle創建帶有參數的視圖代碼介紹 、 Oracle分頁查詢性能優化代碼詳解 、 oracle 虛擬專用數據庫詳細介紹等,感謝大家對本站的支持。有什么問題可以隨時留言,小編會竭盡所能給您想要的答案。

您可能感興趣的文章:
  • Oracle 跨庫 查詢 復制表數據 分布式查詢介紹
  • oracle中通配符和運算符的使用方法介紹
  • Oracle RMAN自動備份控制文件方法介紹
  • Oracle EBS工具選項:關閉其他表單修改方法
  • 淺談oracle rac和分布式數據庫的區別

標簽:滁州 涼山 許昌 遼源 郴州 焦作 合肥 南充

巨人網絡通訊聲明:本文標題《oracle 數據庫啟動階段分析》,本文關鍵詞  oracle,數據庫,啟動,階段,;如發現本文內容存在版權問題,煩請提供相關信息告之我們,我們將及時溝通與處理。本站內容系統采集于網絡,涉及言論、版權與本站無關。
  • 相關文章
  • 下面列出與本文章《oracle 數據庫啟動階段分析》相關的同類信息!
  • 本頁收集關于oracle 數據庫啟動階段分析的相關信息資訊供網民參考!
  • 推薦文章
    校园春色亚洲色图_亚洲视频分类_中文字幕精品一区二区精品_麻豆一区区三区四区产品精品蜜桃
    日韩久久一区二区| 中文成人综合网| 欧美色区777第一页| 欧美亚州韩日在线看免费版国语版 | 麻豆国产一区二区| 美女视频一区在线观看| 麻豆免费看一区二区三区| 美女视频黄免费的久久| 久久精品72免费观看| 激情久久久久久久久久久久久久久久| 日本在线不卡视频| 蜜臀av亚洲一区中文字幕| 裸体一区二区三区| 国产综合久久久久影院| 成人伦理片在线| 一本大道综合伊人精品热热 | 最好看的中文字幕久久| 中文字幕亚洲成人| 亚洲激情欧美激情| 首页综合国产亚洲丝袜| 麻豆精品新av中文字幕| 国产激情偷乱视频一区二区三区 | 欧美成人免费网站| 久久视频一区二区| 国产精品国产三级国产aⅴ中文 | 国产精品久久久久久久蜜臀| 亚洲天堂久久久久久久| 亚洲与欧洲av电影| 蜜臀久久99精品久久久久宅男| 精品亚洲欧美一区| 成人av资源在线| 欧美日韩免费在线视频| 亚洲精品一区二区三区在线观看 | 成人的网站免费观看| 91福利社在线观看| 欧美一区二区二区| 国产精品污www在线观看| 亚洲国产精品久久一线不卡| 久久综合综合久久综合| 成人精品鲁一区一区二区| 欧美亚洲国产一区二区三区va| 日韩一区二区三区在线视频| 中文字幕欧美一区| 日韩一区二区电影在线| 欧美精品一区二区三区久久久| 综合久久综合久久| 日韩激情视频在线观看| 成人性生交大合| 欧美久久一二三四区| 亚洲国产精品成人综合色在线婷婷| 亚洲一区二区精品久久av| 国产福利91精品| 欧美日韩的一区二区| 国产精品日日摸夜夜摸av| 日本欧美一区二区在线观看| 成人av在线看| 欧美成人a在线| 一区二区三区四区中文字幕| 国产剧情av麻豆香蕉精品| 欧美日韩国产成人在线免费| 国产精品乱人伦| 美国精品在线观看| 欧美亚洲禁片免费| 国产精品传媒在线| 精品一区二区三区免费| 欧美区视频在线观看| 中文字幕亚洲欧美在线不卡| 韩国在线一区二区| 91麻豆精品国产91久久久资源速度 | 国产日韩欧美精品一区| 全国精品久久少妇| 欧美综合天天夜夜久久| 日本一区二区三区dvd视频在线| 日韩av不卡一区二区| 91久久人澡人人添人人爽欧美| 久久影院电视剧免费观看| 首页亚洲欧美制服丝腿| 在线看一区二区| 亚洲日本免费电影| 成人av片在线观看| 国产日韩综合av| 韩国成人在线视频| 日韩免费成人网| 青草av.久久免费一区| 欧美亚洲国产怡红院影院| 亚洲乱码国产乱码精品精的特点| 高清日韩电视剧大全免费| 精品国产成人系列| 麻豆专区一区二区三区四区五区| 91精品国产综合久久福利软件| 亚洲一区免费在线观看| 色吧成人激情小说| 18成人在线观看| 成人国产一区二区三区精品| 国产视频一区在线观看| 国产一区二区三区在线观看免费| 日韩欧美一二区| 麻豆freexxxx性91精品| 精品毛片乱码1区2区3区| 免费成人av资源网| 日韩亚洲欧美成人一区| 久久精品久久精品| 欧美精品一区二区蜜臀亚洲| 狠狠色伊人亚洲综合成人| 26uuu国产日韩综合| 国产亚洲1区2区3区| 精品在线免费观看| 精品日韩在线观看| 国产尤物一区二区在线| 久久精品亚洲精品国产欧美| 国产一区二区不卡| 国产精品―色哟哟| 97久久久精品综合88久久| 成人免费在线视频| 欧美最猛黑人xxxxx猛交| 天天综合色天天| 日韩视频在线永久播放| 国产老妇另类xxxxx| 国产精品久久777777| 91麻豆精东视频| 天天色综合天天| 欧美成人国产一区二区| 国产一区在线看| 国产精品的网站| 欧美日韩精品一区二区三区| 久久国产综合精品| 国产精品亲子伦对白| 色综合久久中文综合久久牛| 亚洲v日本v欧美v久久精品| 日韩欧美另类在线| 丰满放荡岳乱妇91ww| 一区二区在线观看视频| 欧美一区二区三区成人| 高清国产一区二区三区| 亚洲一区二区三区在线| 日韩女优视频免费观看| 成人h动漫精品一区二区| 亚洲午夜久久久久久久久电影网| 91精品国产综合久久精品app| 韩国精品久久久| 日韩码欧中文字| 欧美一区二区三区视频免费播放 | 欧美久久一二区| 国产一区二区三区美女| 亚洲精品菠萝久久久久久久| 欧美一卡2卡3卡4卡| 不卡电影一区二区三区| 日韩va亚洲va欧美va久久| 欧美高清在线一区| 欧美久久久久久久久中文字幕| 国产激情视频一区二区三区欧美| 亚洲一区二区三区四区中文字幕| 久久新电视剧免费观看| 欧美在线免费观看亚洲| 国产一区在线观看麻豆| 亚洲一区在线观看网站| 国产色一区二区| 在线成人av网站| www.性欧美| 美美哒免费高清在线观看视频一区二区| 国产精品网曝门| 欧美一区二区三区四区久久| 91亚洲资源网| 国产精品自在欧美一区| 日韩电影一二三区| 亚洲精品欧美在线| 欧美极品aⅴ影院| 日韩欧美一级片| 欧美日韩一区在线| www.视频一区| 国产精品白丝jk白祙喷水网站| 五月天视频一区| 亚洲视频 欧洲视频| 国产亚洲一区二区三区| 欧美一二三区在线观看| 欧美在线一二三| 99国产精品国产精品久久| 国产精品12区| 久久国产尿小便嘘嘘尿| 丝瓜av网站精品一区二区| 一区二区三区四区视频精品免费 | 国产精品麻豆网站| 日韩精品一区在线| 欧美日本一区二区在线观看| 91免费在线看| 成人午夜av电影| 国产精品资源在线观看| 奇米影视一区二区三区| 亚洲电影第三页| 亚洲另类春色国产| 国产精品久久久久毛片软件| 国产日韩欧美高清| 欧美精品一区男女天堂| 日韩欧美在线观看一区二区三区| 欧美性大战久久久久久久蜜臀| 99精品桃花视频在线观看| 不卡在线视频中文字幕| 福利电影一区二区| 国产精品99久久久| 国产精品综合一区二区|