DAY2 搞清楚 Oracle Instance 與Oracle DB 在單實例狀態下的關係,梳理ORACLE體系結構

實驗:切換ORACLE_SID,手動創建一個txt文本,包含以下參數:

DB_NAME='orcl1'

control_files='/opt/oracle/oradata/orcl1/control01.ctl'

compatible='11.2.0.4.0'

(其中compatible針對11.2.0.4有特備作用,不加無法用它掛載數據庫)

掛載這個概念用的很好,可以很好的理解數據庫的交互過程。

實驗過程:在ORACLE_SID=orcl1時關閉數據庫,創建一個新的ORACLE_SID=orcl2,然後創建text.txt文本,寫入必要的參數,11.2.0.3之前版本只需要寫DB_NAME和control_files即可,而11.2.0.4必須要寫compatible參數,不然控制文件裡面默認的數據庫版本都是11.2.0.0。如果不寫,則會報錯:

ORA-00201:control file version 11.2.0.4.0 incompatible with ORACLE version 11.2.0.0.0 ORA-00202:control file : '/oradata/gabsjsb/control01.ctl'

實驗結束可見(show parameter name),實例orcl2實例掛載了數據庫並開啟,

如果此時再在ORACLE_SID=orcl1下掛載並開啟數據庫,將會報錯(ORA-01102: cannot mount database in EXCLUSIVE mode)

以下是別人的應用:

故障描述:

由于数据库所在服务器内核崩溃,经过几个小时的修复也没能挽救回来,只能将数据目录挂载至其他地方然后尝试把数据库拉起来。

结果在启动时出现如下报错

SQL> startup pfile='/home/oracle/initgabsjsb.ora';

ORA-00201control file version 11.2.0.4.0 incompatible with ORACLE version 11.2.0.0.0

ORA-00202control file : '/oradata/gabsjsb/control01.ctl'

产生原因:

11.2.0.4数据库参数文件中如果不写明compatible参数,则默认为11.2.0.0.0,主要是手动创建pfile才会发生,正常创建的数据库基本不需要考虑这种问题

参数文件如下:

*.audit_file_dest='/oracle/admin/gabsjsb/adump'

*.control_files='/oradata/gabsjsb/control01.ctl','/oradata/gabsjsb/control02.ctl'

*.diagnostic_dest='/oracle'

*.db_name='gabsjsb'

*.dispatchers='PROTOCOL=TCP (SERVICE=gabsjsbXDB)'

*.compatible='11.2.0.4.0'

*.db_files=1000

*.processes=3000

關於控制文件版本不一致問題:

ORA-00214: control file '/opt/oracle/oradata/orcl1/control01.ctl' version 1082 inconsistent with file '/opt/oracle/fast_recovery_area/orcl1/control02.ctl' version 946

Version 1082 與Version 946屬於控制文件不一致,1082比946要新,可用1082這個控制文件覆蓋946.

補充1:

補充2:生產狀態下:process最小設置3000

補充3:設置了DB_RECOVERY_FILE_DEST位置及大小即代表了啟用閃回恢復區。

補充4:oracle11g EM 启动报错解决方法

重新配置emctl :emca -config dbcontrol db

常用的命令语法:

emca -repos create创建一个EM资料库

emca -repos recreate重建一个EM资料库

emca -repos drop删除一个EM资料库

emca -config dbcontrol db配置数据库的 Database Control

emca -deconfig dbcontrol db删除数据库的 Database Control配置

emca -reconfig ports 重新配置db control和agent的端口

emctl start console启动EM console服务,使用前需要先设置ORACLE_SID环境变量

emctl stop console停止EM console服务,使用前需要先设置ORACLE_SID环境变量

注:通过查看$ORACLE_HOME/install/portlist.ini 文件可以知道当前dbcontrol正在使用的端口,默认dbcontrol http端口1158,agent端口3938。如果要重新配置端口,可以使用如下命令:

emca -reconfig ports -dbcontrol_http_port 1159

emca -reconfig ports -agent_port 3939

使用命令行工具emctl可以启动/停止console服务,察看服务状态等。

DAY3

 ORACLE 參數查詢

  1. 官方文檔 2.v$parameter 3.v$system_parameter (注意區分兩個試圖的區別)

 報警日誌查詢 v$diag_log (11g開始支持)

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值