考试安排
OCM考试一共有9个section,具体的安排如下:
第一天:
section 0:
创建一个数据库 45分钟
section 1:
数据库和网络配置 120分钟
section 2:
Gridcontrol安装配置 120分钟
section 3:
数据库备份恢复 60分钟
section 4:
数据仓库管理 90分钟
第二天:
section 5:
数据库管理 120分钟
section 6:
数据库性能管理 120分钟
section 7:
部署Oracle RAC数据库 105分钟
sectoin 8:
部署dataguard数据库 60分钟
考试的内容:
15分钟熟悉考前环境,上海的考场的机器配置很差,1G内存 1CPU的
一、手动建库
如果自己打命令创建数据库的话时间会很紧张,我采用的方法是:
1. 设置环境变量
ORACLE_SID
参照考题中需要创建的数据库SID,设置操作系统环境变量,假设要求创建的数据库的SID是TEST。
2.手工创建如下目录:
$ORACLE_BASE/admin/test/cdump
$ORACLE_BASE/admin/test/bdump
$ORACLE_BASE/admin/test/udump
$ORACLE_BASE/admin/test/adump
$ORACLE_BASE/oradata/test
3. 创建最简单的initTEST.ora文件
在$ORALCE_HOME/dbs下可以找到一份已经存在的init.ora文件,这是一份样本(在正式
考试的机器上你也可以找到)。打开这份文件可以看到很多被注释的行,让人烦躁,一行一
行地修改这个文件比较耗时,使用下面的命令,把所有以#开头和所有的空行全部过滤掉,
同时生成最简单的initTEST.ora初始化参数文件。
$> catinit.ora | grep -v ^# | grep -v ^$ > initSID.ora
然后修改该文件的db_name参数和control_files参数(控制文件放在哪里,需要多少份控制
文件,在考题中会清楚地提出要求),其它的参数保持原状不需要修改。
db_name=TEST
control_files=("/oracle/oradata/TEST/controlfile01.dbf")
sga_max_size=280M
sga_target=280M
note:
删除其他内存参数
4.启动数据库到nomount状态
此时已经有可供启动的初始化参数文件了,将数据库启动到
nomount
状态。
SQL> startup nomount;
5.
创建spfile实例启动以后立刻创建spfile,然后重启一次数据库,让数据库能够使用到spfile。
6.修改其它必须的初始化参数
为什么需要先快速地将实例启动到nomount状态?因为我们需要使用show parameter
命令,在记不清楚那些初始化参数具体怎么敲的时候,show parameter命令能够来帮助我们快速定
位其它必须要修改的初始化参数名字的写法。
因为用到了spfile,所以此处我们已经可以使用alter system命令来修改初始化参数了。
db_block_size=8192
background_dump_dest=/oracle/product/RAC10G/admin/test01/bdump
core_dump_dest=/oracle/product/RAC10G/admin/test01/cdump
user_dump_dest=/oracle/product/RAC10G/admin/test01/udump
audit_file_dest=/oracle/product/RAC10G/admin/test01/udump
db_create_file_dest =
考题中要求你创建数据文件时存放的目录
db_create_online_log_dest_1 =
考题中要求你创建联机重做日志文件时存放的目录
undo_management=auto
undo_tablespace=undotbs1
#创建em时需要job_queue_processes>1
job_queue_processes=5
不要一条命令一条命令在SQL*Plus里面敲,用vi或者Text Editor将所有的alter system
命令都编辑好,然后一次执行。执行完毕以后,关闭实例,再重新启动到nomount
状态,让刚才修改的初始化参数生效。
7.创建密码文件
用orapwd程序创建orapwTEST密码文件,如果记不清楚orapwd程序怎么用,直接敲
orapwd然后回车,会告诉你语法是怎样的。
orapwd file=$ORACLE_HOME/dbs/orapwSID password=oracle entries=5
8.创建数据库
要快速找到例句,如果你去查SQLReference文档中的createdatabase的语法,时间肯定是
比较紧张的,我们要查的是Administrator’s Guide这本文档中第二章
Creating an Oracle Database -> Creatingthe database ->
Step 7: Issue the CREATE DATABASE Statement
,这里有完整的一条SQL语句,copy出来,然后按照考试要求去编辑相应的地方,
然后执行,这样出来的命令基本上不会出现问题。
注意数据文件分布到
disk1~disk5
CREATE DATABASE TEST
USER SYS IDENTIFIED BY oracle
USER SYSTEM IDENTIFIED BY oracle
LOGFILE GROUP 1('/oracle/oradata/test/redo01.log') SIZE 10M,
GROUP 2 ('/oracle/oradata/test/redo02.log') SIZE 10M,
GROUP 3 ('/oracle/oradata/test/redo03.log') SIZE 10M
MAXLOGFILES 30
MAXLOGMEMBERS 5
MAXLOGHISTORY 1
MAXDATAFILES 200
MAXINSTANCES 2
CHARACTER SET ZHS16GBK
NATIONAL CHARACTER SET AL16UTF16
DATAFILE'/oracle/oradata/test/system01.dbf' SIZE 325M REUSE EXTENT MANAGEMENT
LOCAL
SYSAUX DATAFILE'/oracle/oradata/test/sysaux01.dbf' SIZE 325M REUSE
DEFAULT TEMPORARY TABLESPACE tempts1TEMPFILE '/oracle/oradata/test/temp01.dbf'
SIZE 20M REUSE
UNDO TABLESPACE undotbs1 DATAFILE'/oracle/oradata/test/undotbs01.dbf'
SIZE 200M REUSE AUTOEXTEND ON MAXSIZEUNLIMITED;
#创建缺省表空间
CREATE SMALLFILE TABLESPACE"USERS" LOGGING DATAFILE
'/oracle/oradata/test1/users01.dbf'
SIZE 5M REUSE AUTOEXTEND ON NEXT 1280K MAXSIZE UNLIMITED EXTENT
MANAGEMENT LOCAL SEGMENT SPACEMANAGEMENT AUTO ;
ALTER DATABASE DEFAULT TABLESPACE"USERS";
NOTE:
修改
MAXLOGFILES,undo,default
9.运行catalog.sql 和 catproc.sql
只需要运行这两个SQL,都在$ORACLE_HOME/rdbms/admin中,创建必须的数据字典和内置的
package等
optional:
connect /as sysdba
@?/rdbms/admin/catblock.sql
@?/rdbms/admin/catoctk.sql
@?/rdbms/admin/owminst.plb
connect system/oracle
@?/sqlplus/admin/pupbld.sql
@?/sqlplus/admin/help/hlpbld.sql helpus.sql
Note :section0中没有要求你运行catalog,catproc脚本,但是如果时间有多我建议在
section 0中就运行这2个脚本为下一个section节省时间.
二、配置数据库和网络
1.修改数据库几个参数
2.按照要求创建几个表空间
3.网络配置
创建监听
考试可能会要求你创建非默认端口(1521)的监听,并且要求实例自动注册到这个监听上,
那么这时候需要配置listener.ora和 tnsnames.ora,并且修改local_listener参数
MTS配置
三、gridcontrol
#安装
每个人面前会有两台机器,一台称为奇数机(ODD),一台称为偶数机(EVEN),注意,考
题上也会这样表述的,要你在ODD机器上做什么或者在 EVEN 机器上做什么,偶数还是
奇数是依靠机器的hostname最后一位或者两位数字来定的,通常会要求你在奇数机上创建
数据库,在偶数机上安装GridControl的OMS。
偶数机上是没有Oracle软件的,因此OMS需要的Repository这个数据库也需要创建在奇数机上,再加上之后第二天会要求创建的Standby实例,总共会有三个实例运行在奇数机上,上海机器的内存是1G,所以一定要预先考虑好分配给每个实例的内存。为什么上午就要求配置监听?因为下午的考试中OMS需要通过监听来访问创建的数据库,总之,OCM考试中基本上都是这样环环相扣的,其中某一步做慢了或者没完成就很可能影响接下来的考试。
Grid Control的安装软件会预先放置在偶数机的某个目录下,考题里面会告诉你的。但是,
不要着急安装,为了一次就安装成功我们需要预先做一些工作。再次强调一下,安装OMS
我们基本上只有一次的机会,因为大部分的错误都会是在等待了一个漫长的Configuration
过程之后再报出来,而这时候通常已经没有剩余的时间让你去找到问题发生的原因,然后清
理已经安装了残迹再重新安装OMS了。
1. Use DBCA
按照要求,通常会创建一个新数据库在奇数机上(不同于上午的Section中要求创建的SID),用于存储OMS需要的Repository信息,下午的时候应该是已经可以使用图形界面了,所以
我们可以用dbca来创建这个数据库。
2. Check Pacakage
数据库创建完毕以后,也许仍然你习惯用手动的方法创建,所以请检查数据库里面有没有
dbms_shared_pool这个package,如果没有,运行$ORACLE_HOME/rdbms/admin/dbmspool.sql
来创建这个package,因为安装OMS时候某些自动的检查需要调用这个包,没有的话将会
报错。
3. Implement SSH
快速地建立两台机器之间的ssh信任关系,如果还不会的,请务必去网上查资料并且牢记每
一步操作。这里有个小陷阱,默认情况下,两台机器上的oracle 用户的home目录权限是
0777,也就是完全的可读些权限,但是在这种情况下,建立oracle用户的ssh信任关系,即
使你完全配正确了,也同样无法正常地不输入密码就登陆到另外一台机器上。据说很多人折
在这里,怎么也配不通两机的信任关系,那时候焦躁的心情应该可想而之了。需要做的是将
oracle用户的home目录权限改为0755。
这步是可选的有些兄弟没配置也能安装成功的
4. Transfer X Window
尽量在一台机器上操作,不要在两台机器面前一会儿敲敲这个的键盘,一会儿动动那个的鼠
标。字符界面的话,用terminalssh过去就可以了,图形界面呢?不需要费劲地去检查
vnc server有没有启动,启动在哪个端口了什么的,直接用ssh -X hostname这样的方式,就可以将远程的X界面显示在本机上。
5. Follow the Error Messege
安装OMS,对于Repository库是有一些初始化参数的要求的,比如java池该多大,shared pool
该多大,job queue该多大,但是不要去阅读安装文档,那个浪费时间。我们需要做的就是设置SGA_TARGET= 300M,这样内存参数就自动管理了,安装OMS不会报任何错误,另
外对于job queue等其它的参数,在点击开始安装之后的某个界面,会弹出一个警告框,告
诉你哪些参数不符合要求,需要改为多少多少,OK,安装这个界面里的要求,依次修改数
据库的参数,然后重新启动数据库,不需要退出安装界面,在重启完数据库之后,点确定,
直接继续安装就可以了。
6. Be Patient
要有耐心,OMS安装的时候,在Configuration那一步时会非常慢,千万不要等不及了就准
备关掉重来,时刻监控安装的log文件(log文件的位置在安装界面上应该可以找到),只要
不停地有输出,你就可以安心地等待。
7. Install Agent
OMS安装完毕,也启动成功了。还需要在奇数机上安装Grid Control的Agent,有好多种方
法可以安装,但是我们需要选择最简单最快速的方法,那就是使用agentDownload.linux程序,将这个程序从偶数机的OMS安装目录中copy到奇数机的某个目录下,随便哪个目录
都行。然后运行下面的命令:
./agentDownload.linux -b/u01/app/oracle/product
最后一个参数是我们希望将agent安装到的BASE目录。
用这种方法安装Agent的速度很快,而且无需任何人工参与
8. Learning GUI
OMS也启动了,Agent也启动了,通过浏览器去检查一下Grid Control的管理界面是不是好
用吧,到这里,基本上就没什么问题了,下面会是一些要求你通过Grid Control来创建一些
表空间或者一些用户或者一些什么别的操作,按照要求来就好。不过,对于命令行死忠派来
说,还是预先去熟悉一下图形界面的操作吧,否则到时候找个按钮都要找半天。
9. Lucky
这次考试中有个兄弟特别背,考着考着鼠标就动不了了。。考着考着数据库就自己down了。
所以运气也是很重要的
#配置
新建一个管理员用户
配置email通知创建
schedule,program,windows,job
三、数据库备份恢复
丢失一个controlfile的恢复
1.创建catalog 数据库
2.rman 备份
1.set rman env
rman target sys/oracle catalogrman/rman@test1
RMAN>CONFIGURE DEFAULT DEVICE TYPE TODISK;
RMAN>CONFIGURE CHANNEL DEVICE TYPE DISK FORMAT
'/oracle/oradata/orcl/backup/DB_%U';
RMAN>CONFIGURE CONTROLFILE AUTOBACKUPON;
RMAN>CONFIGURE CONTROLFILE AUTOBACKUPFORMAT FOR DEVICE TYPE DISK
TO'/oracle/oradata/orcl/backup/cf_%F';
RMAN>CONFIGURE BACKUP OPTIMIZATIONONptimization does not back up a file to a
device type if the identical file isalready backed up on the device type.
For two files to be identical, theircontent must be exactly the same.
要求设置compress备份,
具体命令有点忘记了。。可以查一下联机帮助
2.RMAN Online Full Database Backup
#scripts:bck_db_level0.rcv
run {
BACKUP INCREMENTAL LEVEL 0 DATABASE;
BACKUP ARCHIVELOG ALL DELETE ALL INPUT;
}
#run rman backup
rman target sys/oracle@orcl catalogrman/rman@test1 @bck_db_level0.rcv log
bck_db_level0.log
recovery
datafile 1
丢失的恢复
3.配置flashback 数据库
四、数据仓库
select distinct a,b from t1;
要求创建一个能够快速刷新的物化视图创建一个可刷新的物化视图外部表会考datapump
方式的导出和导入,Oracle_loader的外部表也会考
五、数据库管理
exp,imp
transport tablespace
创建分区表
创建分区索引
global hash
和localtruncate partition 创建带clob字段的表
使用FGA对一张表做审计(可以参考联机帮助)flashback table tobefore drop rename to xxx; (注意要flashback到包含某个字段的,show recyclebin)
考试内容和考纲比较吻合
六、性能管理
创建IOT表
创建bitmap Index,functionindex 统计信息收集表空间使用ASSM以减少buffer busywait
Statspack
安装使用level 7产生snap 创建一个Job 每5分钟运行一次按照指定路径生成report文件outline也考了。
七、RAC 安装
crs、asm和db软件创建 rac db 添加service 启用archive 时间应该足够,剩下的时间,我是用来将下一节中手工创建dataguard需要用到的sql和参数修改都事先编辑好
八、datagurad
1.在奇数机器上创建physical standby
2.添加standby logfile ,使用lgwr async方式
3.切换到standby ,运行一个脚本,然后在切换回,运行一个脚本
4.read only打开standby