很多人对Oracle 10g推出的ASM技术感到畏惧,总觉得是一个black box,自己驾御不了,其实呢,ASM并不是黑匣子,只是大家还没有xx掌握她、了解她。本小结不对ASM技术本身做过多的介绍,假设你对ASM技术有了一定的了解(至少看过一些别人的案例或相关的技术白皮书什么的吧?),本文介绍一个在Windows XP环境下构建一个基于ASM的Oracle 10g(10.2.0.4)单机的数据库,从而给大家提供一个ASM的学习环境,从而尽快的了解ASM,让她变的不再陌生!
在Windows平台下,Oracle提供了一个工具叫asmtool(位于%ORACLE_HOME%bin目录下),通过asmtool可以构建虚拟ASM磁盘,从而让我们有了一个可以在虚拟ASM磁盘上建立学习环境的机会。
不过大家要注意,这种方法不是官方支持的的,所以千万不要用于生产系统,xx于学习研究
{dy}步:创建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 bytesORA-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实例
|