前言
很多人对Oracle 10g推出的ASM技术感到畏惧,总觉得是一个black box,自己驾御不了,其实呢,ASM并不是黑匣子,只是大家还没有完全掌握她、了解她。本小结不对ASM技术本身做过多的介绍,假设你对ASM技术有了一定的了解(至少看过一些别人的案例或相关的技术白皮书什么的吧?),本文介绍一个在Windows XP环境下构建一个基于ASM的Oracle 10g(10.2.0.4)单机的数据库,从而给大家提供一个ASM的学习环境,从而尽快的了解ASM,让她变的不再陌生!
在Windows平台下,Oracle提供了一个工具叫asmtool(位于%ORACLE_HOME%bin目录下),通过asmtool可以构建虚拟ASM磁盘,从而让我们有了一个可以在虚拟ASM磁盘上建立学习环境的机会。
不过大家要注意,这种方法不是官方支持的的,所以千万不要用于生产系统,仅限于学习研究
第一部分:创建ASM实例
第一步:创建ASM虚拟磁盘
在我这个个测试中,我总共创建4个diskgroup,下面创建的asm磁盘的单位是M
asmtool -create d:asmdiskasmdisk1 500 asmtool -create d:asmdiskasmdisk2 500 asmtool -create d:asmdiskasmdisk3 500 -- SYS_DATA External Redundancy asmtool -create d:asmdiskasmdisk4 200 asmtool -create d:asmdiskasmdisk5 200 -- FLASH_DATA External Redundancy asmtool -create d:asmdiskasmdisk6 100 asmtool -create d:asmdiskasmdisk7 100 -- USER_DATA Normal Redundancy
asmtool -create d:asmdiskasmdisk8 100 asmtool -create d:asmdiskasmdisk9 100
asmtool -create d:asmdiskasmdisk10 100 -- TEST_DATA High Redundancy
具体的执行过程就略了。执行完了的结果就是:
D:oracle10g>dir d:asmdisk
驱动器 D 中的卷是 应用盘 卷的序列号是 64B6-D634
d:asmdisk 的目录
2009-07-13 09:51 <DIR> . 2009-07-13 09:51 <DIR> .. 2009-07-13 09:42 524,288,000 asmdisk1 2009-07-13 09:51 104,857,600 asmdisk10 2009-07-13 09:44 524,288,000 asmdisk2 2009-07-13 09:46 524,288,000 asmdisk3 2009-07-13 09:46 209,715,200 asmdisk4 2009-07-13 09:47 209,715,200 asmdisk5 2009-07-13 09:47 104,857,600 asmdisk6 2009-07-13 09:47 104,857,600 asmdisk7 2009-07-13 09:48 104,857,600 asmdisk8 2009-07-13 09:48 104,857,600 asmdisk9 10 个文件 2,516,582,400 字节 2 个目录 7,263,399,936 可用字节 D:oracle10g>
第二步:
配置CSS(Cluster Synchronization Services)
CSS主要用来同步ASM instance和它的client,也即database instance。可以由Oracle自带的localconfig命令来完成。Localconfig命令也位于ORACLE_HOMEbin目录下.
%ORACLE_HOME%binlocalconfig add
D:oracle10g>localconfig add
Step 1: creating new OCR repository Successfully accumulated necessary OCR keys. Creating OCR keys for user 'zhangrp', privgrp ''.. Operation successful. Step 2: creating new CSS service successfully created local CSS service successfully added CSS to home
D:oracle10g>
配置完成后,在Windows Services中会出现类似如下一个entry
--检查CSS守护进程的状态
D:oracle10g>crsctl check cssd
CSS appears healthy D:oracle10g>
备注
:如果后期要删除这个css服务,只需要在windows command下执行如下命令即可:
localconfig delete
第三步:准备ASM实例的参数文件
注意
:ASM的实例名一定要以+开头的字符串,比如+ASM,否则后面通过dbca配置ASM实例或创建数据库的时候,DBCA无法识别到之前的asm实例。
参见Metalink Doc ID: 403644.1
先创建一个pfile文件,我的这个测试ASM实例的名字就叫+ASM,所以我需要在%ORACLE_HOME%database下创建一个INIT+asm.ORA的参数文件,内容如下:
*._asm_allow_only_raw_disks=FALSE *.asm_diskstring='D:asmdiskasmdisk*' *.background_dump_dest='D:adminasmbdump' *.core_dump_dest='D:adminasmcdump' *.instance_type='ASM' *.large_pool_size=12M
*.db_unique_name='+ASM'
*.asm_power_limit=1 *.remote_login_passwordfile='SHARED' *.user_dump_dest='D:adminasmudump'
注意
:此处"_asm_allow_only_raw_disks"为隐含参数,设为FALSE是为了允许ASM使用非裸设备,在这里是必须要设置为FALSE的。
第四步:创建ASM实例
D:oracle10g>oradim -new -asmsid +asm -startmode manual Instance created.
备注
:如果后期要删除这个asm实例,只需要在windows command下执行如下命令即可:
oradim -delete -asmsid +asm
第五步:连接到ASM实例
D:oracle10g>set ORACLE_SID=+ASM
Microsoft Windows XP [版本 5.1.2600] (C) 版权所有 1985-2001 Microsoft Corp.
D:oracle10g>sqlplus "/as sysdba"
SQL*Plus: Release 10.2.0.4.0 - Production on Mon Jul 13 10:15:33 2009 Copyright (c) 1982, 2007, Oracle. All Rights Reserved.
Connected to an idle instance. SQL> startup
ASM instance started
Total System Global Area 83886080 bytes Fixed Size 1295152 bytes Variable Size 57425104 bytes ASM Cache 25165824 bytes
ORA-15110
: no diskgroups mounted SQL>
注意
:这里有一个ORA-15110的错误信息,因为是首次启动asm实例,还没有创建diskgroup,所以显示15110错误是正常的,忽略掉该错误,继续后面的步骤。
SQL> select host_name,instance_name,version,status from v$instance;
HOST_NAME INSTANCE_NAME VERSION STATUS --------------- -------------- ------------- ---------- zhangrp-cn +asm 10.2.0.4.0 STARTED
第六步:创建磁盘组
按照我之前的规划,我这里需要创建4个磁盘组.
--查看一下磁盘信息 SQL> col path for a30
SQL> select path,mount_status from v$asm_disk order by disk_number;
PATH MOUNT_STATUS ---------------------- -------------- D:ASMDISKASMDISK1 CLOSED D:ASMDISKASMDISK10 CLOSED D:ASMDISKASMDISK2 CLOSED D:ASMDISKASMDISK3 CLOSED D:ASMDISKASMDISK4 CLOSED D:ASMDISKASMDISK5 CLOSED D:ASMDISKASMDISK6 CLOSED D:ASMDISKASMDISK7 CLOSED D:ASMDISKASMDISK8 CLOSED D:ASMDISKASMDISK9 CLOSED
10 rows selected. SQL>
可以看到,我之前创建的10块ASM虚拟磁盘mount 状态全是closed,因为他们还没有被加到任何的diskgroup中.下面开始创建我的diskgroup
--系统用的磁盘组SYS_DATA,由3块500M的磁盘组成,采用外部冗余
SQL> create diskgroup sys_data
2
External Redundancy
3 disk 'd:asmdiskasmdisk1',
4 'd:asmdiskasmdisk2',
5 'd:asmdiskasmdisk3';
Diskgroup created. --闪回用的磁盘组FLASH_DATA,由2块200M的磁盘组成,采用外部冗余 SQL> create diskgroup flash_data
2
External Redundancy
3 disk 'd:asmdiskasmdisk4',
4 'd:asmdiskasmdisk5';
Diskgroup created. --用户STUDY用的磁盘组USER_DATA,由2块100M的磁盘组成,采用2-way冗余 SQL> create diskgroup user_data
2
Normal Redundancy
3 failgroup user_fg_01 disk 'd:asmdiskasmdisk6'
4 failgroup user_fg_02 disk 'd:asmdiskasmdisk7';
Diskgroup created. --测试用的磁盘组TEST_DATA,由3块100M的磁盘组成,采用3-way冗余 SQL> create diskgroup test_data
2
High Redundancy
3 failgroup test_fg_01 disk 'd:asmdiskasmdisk8'
4 failgroup test_fg_02 disk 'd:asmdiskasmdisk9'
5 failgroup test_fg_03 disk 'd:asmdiskasmdisk10';
Diskgroup created. SQL>
--再看一下磁盘的状态
SQL> select path,mount_status from v$asm_disk order by disk_number;
PATH MOUNT_STATUS ---------------------- -------------- D:ASMDISKASMDISK1 CACHED D:ASMDISKASMDISK10 CACHED D:ASMDISKASMDISK2 CACHED D:ASMDISKASMDISK3 CACHED D:ASMDISKASMDISK4 CACHED D:ASMDISKASMDISK5 CACHED D:ASMDISKASMDISK6 CACHED D:ASMDISKASMDISK7 CACHED D:ASMDISKASMDISK8 CACHED D:ASMDISKASMDISK9 CACHED
10 rows selected. SQL>
这时的磁盘状态,MOUNT_STATUS变成"CACHED",表示磁盘已经成为磁盘组的一部分,并且正在被ASM Instance访问
SQL> select group_number,name,sector_size,block_size,allocation_unit_size,state,type,total_mb,free_mb from v$asm_diskgroup;
GROUP_NUMBER NAME SECTOR_SIZE BLOCK_SIZE ALLOCATION_UNIT_SIZE STATE TYPE TOTAL_MB FREE_MB ------------ ----------- ----------- ---------- -------------------- --------- ------ ---------- ------- 1 FLASH_DATA 512 4096 1048576 MOUNTED EXTERN 400 348 2 SYS_DATA 512 4096 1048576 MOUNTED EXTERN 1500 1446 3 TEST_DATA 512 4096 1048576 MOUNTED HIGH 300 147 4 USER_DATA 512 4096 1048576 MOUNTED NORMAL 200 98 SQL>
SQL> show parameter asm_disk
NAME TYPE VALUE ------------------ ----------- ------------------------------------------ asm_diskgroups string SYS_DATA, FLASH_DATA, USER_DATA, TEST_DATA asm_diskstring string D:asmdiskasmdisk* SQL>
第七步:关闭ASM实例,修改pfile并转为spfile,创建密码文件
在这一步中,先关闭ASM实例,然后修改pfile,增加如下参数:
asm_diskgroups='SYS_DATA', 'FLASH_DATA', 'USER_DATA', 'TEST_DATA'
--关闭ASM实例
SQL> shutdown immediate;
ASM diskgroups dismounted ASM instance shutdown --编辑INITasm.ORA参数文件,增加asm_diskgroups设置保存退出。内容如下
SQL> host more d:oracle10gdatabaseINITasm.ORA
*._asm_allow_only_raw_disks=FALSE *.asm_diskstring='D:asmdiskasmdisk*' *.asm_diskgroups='SYS_DATA', 'FLASH_DATA', 'USER_DATA', 'TEST_DATA' *.background_dump_dest='D:adminasmbdump' *.core_dump_dest='D:adminasmcdump' *.instance_type='ASM' *.large_pool_size=12M *.db_unique_name='ASM' *.asm_power_limit=1 *.remote_login_passwordfile='SHARED' *.user_dump_dest='D:adminasmudump'
--创建密码文件
D:oracle10g>orapwd file=d:oracle10gdatabasePWDasm.ora password=admin entries=10
D:oracle10g>
--重启ASM实例 SQL> startup
ASM instance started
Total System Global Area 83886080 bytes Fixed Size 1295152 bytes Variable Size 57425104 bytes ASM Cache 25165824 bytes ASM diskgroups mounted SQL>
好了,刚才的
"ORA-15110
: no diskgroups mounted"错误信息也没了。
--生成SPFILE
SQL> create spfile from pfile;
File created. SQL>
--配置listener.ora和tnsnames.ora,这样就可以通过pl/sql developer这样的工具连接访问你的ASM实例了。参见我另外的文章:如何从远程连接ASM实例
|