尽管Oracle缺省都是使用裸设备来创建ASM磁盘,但其实Oracle也允许使用普通文件来创建ASM磁盘,

当然这种方法最好只用在测试环境下或者学习环境下,不能用在生产环境下。之所以必须要用裸设备,

是因为有一个隐含参数_asm_allow_only_raw_disks在起作用。

通过SQL查看ASM参数:

set lines
col name for a30
col value for a10
col DESCRIPTION for a50 SQL> select x.ksppinm name,y.ksppstvl value,x.ksppdesc description
from x$ksppi x,x$ksppcv y
where x.inst_id=userenv('Instance')
and y.inst_id=userenv('Instance')
and x.indx=y.indx
and x.ksppinm like '_asm_allow_only_raw_disks%'
order by name; NAME VALUE DESCRIPTION
------------------------------ ---------- --------------------------------------------------
_asm_allow_only_raw_disks TRUE Discovery only raw devices

只要把这个参数改成FALSE,我们就可以使用文件来创建ASM了。试验如下:

1.使用dd命令创建几个文件

[oracle@std u02]$ mkdir asmfile
[oracle@std u02]$ cd asmfile/
[oracle@std asmfile]$ dd if=/dev/zero of=cp1 bs=1M count=
+ records in
+ records out
bytes ( MB) copied, 5.50622 seconds, 95.2 MB/s
[oracle@std asmfile]$ dd if=/dev/zero of=cp2 bs=1M count=
+ records in
+ records out
bytes ( MB) copied, 7.13052 seconds, 73.5 MB/s
[oracle@std asmfile]$ dd if=/dev/zero of=cp3 bs=1M count=
+ records in
+ records out
bytes ( MB) copied, 6.60984 seconds, 79.3 MB/s
[oracle@std asmfile]$ dd if=/dev/zero of=cp4 bs=1M count=
+ records in
+ records out
bytes ( MB) copied, 5.31099 seconds, 98.7 MB/s
[oracle@std asmfile]$ ls -l
total
-rw-r--r-- oracle oinstall Feb : cp1
-rw-r--r-- oracle oinstall Feb : cp2
-rw-r--r-- oracle oinstall Feb : cp3
-rw-r--r-- oracle oinstall Feb : cp4

2.创建asm参数文件并修改asm_diskstring

--注意asm_diskstrint参数设置

[oracle@std dbs]$ cp init+ASM.ora  init+ASM2.ora
[oracle@std dbs]$ vi init+ASM2.ora
[oracle@std dbs]$ cat init+ASM2.ora
*.asm_diskstring='/u02/asmfile/cp*'
*.instance_type='asm'
*.large_pool_size=24M
*.remote_login_passwordfile='SHARED'
*.background_dump_dest='/u02/app/admin/+ASM2/bdump'
*.core_dump_dest='/u02/app/admin/+ASM2/cdump'
*.user_dump_dest='/u02/app/admin/+ASM2/bdump'

3.启动ASM实例

[oracle@std dbs]$ export ORACLE_SID=+ASM2
[oracle@std dbs]$ sqlplus '/as sysdba' SQL*Plus: Release 10.2.0.4. - Production on Mon Feb :: Copyright (c) , , Oracle. All Rights Reserved. Connected to an idle instance. SQL> startup
ASM instance started Total System Global Area bytes
Fixed Size bytes
Variable Size bytes
ASM Cache bytes
ORA-: no diskgroups mounted SQL> select path from v$asm_disk; no rows selected

启动ASM实例后还看不到我们asm_diskstring参数指定的设置!!!

4.修改隐含参数,重启ASM实例

[oracle@std dbs]$ vi init+ASM2.ora
[oracle@std dbs]$ cat init+ASM2.ora
*.asm_diskstring='/u02/asmfile/cp*'
*.instance_type='asm'
*.large_pool_size=24M
*.remote_login_passwordfile='SHARED'
*.background_dump_dest='/u02/app/admin/+ASM2/bdump'
*.core_dump_dest='/u02/app/admin/+ASM2/cdump'
*.user_dump_dest='/u02/app/admin/+ASM2/bdump'
_asm_allow_only_raw_disks= FALSE
[oracle@std dbs]$ export ORACLE_SID=+ASM2
[oracle@std dbs]$ sqlplus '/as sysdba' SQL*Plus: Release 10.2.0.4. - Production on Mon Feb :: Copyright (c) , , Oracle. All Rights Reserved. Connected to an idle instance. SQL> startup
ASM instance started Total System Global Area bytes
Fixed Size bytes
Variable Size bytes
ASM Cache bytes
ORA-: no diskgroups mounted SQL> select path from v$asm_disk; PATH
--------------------------------------------------------------------------------
/u02/asmfile/cp4
/u02/asmfile/cp1
/u02/asmfile/cp2
/u02/asmfile/cp3

现在可以看到修改参数后可以看到asm_diskstring参数指定的磁盘了,现在看一下是否能够创建磁盘组

5.创建磁盘组

--注意这些创建的磁盘组不会写入init+ASM2.ora,因为我们当前使用的是pfile,重启实例会丢失。

SQL> create diskgroup dg normal redundancy disk
'/u02/asmfile/cp1','/u02/asmfile/cp2' name dg_data; Diskgroup created. SQL> create diskgroup back normal redundancy
disk '/u02/asmfile/cp3','/u02/asmfile/cp4' name backup_data; Diskgroup created.

--每个磁盘都分配了名字

SQL> select name,path from v$asm_disk;

NAME                 PATH
-------------------- --------------------------------------------------
BACKUP_DATA /u02/asmfile/cp4
BACK_0000 /u02/asmfile/cp3
DG_DATA /u02/asmfile/cp2
DG_0000 /u02/asmfile/cp1

6.查看磁盘组的属性

SQL> select name,block_size,allocation_unit_size from v$asm_diskgroup;

NAME                 BLOCK_SIZE ALLOCATION_UNIT_SIZE
-------------------- ---------- --------------------
DG
BACK

上面的SQL查询了磁盘组的数据块大小及分配单元,其实这两个属性也是由隐含参数控制的,

--查询ASM的隐含参数,这些参数没有十足的把握尽量不要修改

SQL> set lines
SQL> col name for a30
SQL> col value for a10
SQL> col DESCRIPTION for a50
SQL> select x.ksppinm name,y.ksppstvl value,x.ksppdesc description
from x$ksppi x,x$ksppcv y
where x.inst_id=userenv('Instance')
and y.inst_id=userenv('Instance')
and x.indx=y.indx
and x.ksppinm like '_asm%'
order by name; NAME VALUE DESCRIPTION
------------------------------ ---------- --------------------------------------------------
_asm_acd_chunks initial ACD chunks created
_asm_allow_only_raw_disks FALSE Discovery only raw devices
_asm_allow_resilver_corruption FALSE Enable disk resilvering for external redundancy
_asm_ausize allocation unit size --指定了分配单元
_asm_blksize metadata block size --指定了数据块大小
_asm_disk_repair_time seconds to wait before dropping a failing disk
_asm_droptimeout timeout before offlined disks get dropped (in 3s t
icks) _asm_emulmax max number of concurrent disks to emulate I/O erro
rs NAME VALUE DESCRIPTION
------------------------------ ---------- -------------------------------------------------- _asm_emultimeout timeout before emulation begins (in 3s ticks)
_asm_kfdpevent KFDP event
_asm_libraries ufs library search order for discovery
_asm_maxio Maximum size of individual I/O request
_asm_skip_resize_check FALSE skip the checking of the clients for s/w compatibi
lity for resize _asm_stripesize ASM file stripe size
_asm_stripewidth ASM file stripe width
_asm_wait_time Max/imum time to wait before asmb exits NAME VALUE DESCRIPTION
------------------------------ ---------- --------------------------------------------------
_asmlib_test Osmlib test event
_asmsid asm ASM instance id rows selected. SQL>

致谢:本文章参考了张晓明<<大话Oracle RAC 集群 高可用性 备份与恢复>>

使用文件模拟ASM磁盘的更多相关文章

  1. 【翻译自mos文章】将expdp的dmp文件从asm磁盘组里边放到本地文件系统里边

    将expdp的dmp文件从asm磁盘组里边放到本地文件系统里边 參考原文: How To Extract Datapump File From ASM Diskgroup To Local Files ...

  2. 普通文件迁移ASM

    1.ASM Access Through FTP and HTML Using XDB Configuration 2.rman 3.dbms_file_transfer 4.11g asmcmd 利 ...

  3. 单机静默安装GI软件并创建ASM实例和ASM磁盘组

    环境:RHEL 6.4 + Oracle 11.2.0.4 需求:单机静默安装GI软件并创建ASM实例和ASM磁盘组,为后续迁移数据库文件到ASM做准备 1. 安装配置GI软件 2. 创建ASM实例 ...

  4. 99-oracle-asmdevices.rules(udev方式创建asm磁盘)

    一.创建asm磁盘的几种方式 创建asm方式很多主要有以下几种 1.Faking方式 2.裸设备方式 3.udev方式(它下面有两种方式) 3.1 uuid方式. 3.2 raw方式(裸设备方式) 4 ...

  5. ORACLE误删除ASM磁盘修复

    在数据库运维中,总会遇到一些粗心大意的DBA,一不小心删除一些东西,这里举例讲解在误删除ASM磁盘之后,如果用KFED工具进行恢复: [grid@RAC1 ~]$ sqlplus / as sysas ...

  6. 使用asmcmdcp命令把datafile从文件系统移动(move)到asm磁盘组中 针对11gR2

    使用asmcmd cp命令 把datafile从文件系统移动(move)到asm磁盘组中--针对11gR2 参考原文:How to Move a Datafile from Filesystem to ...

  7. 11G ORACLE RAC DBCA 无法识别asm磁盘组

    ASM磁盘无法识别几种现象: 1) gi家目录或者其子目录权限错误 2)asm磁盘的权限错误 3)asm实例未启动或者asm磁盘组没有mount上 4)asm磁盘组资源没有在线 5)oracle用户的 ...

  8. 【翻译自mos文章】回收 asm磁盘空间的方法

    回收 asm磁盘空间的方法 參考原文: How To Reclaim Asm Disk Space? (Doc ID 351866.1) 适用于: Oracle Database - Enterpri ...

  9. 案例:Oracle报错ASM磁盘组不存在或没有mount

    案例:Oracle报错ASM磁盘组不存在或没有mount 环境:RHEL 6.5 + Oracle Standby RAC 11.2.0.4 我做Standby RAC实验时,在恢复控制文件时,报错无 ...

随机推荐

  1. 【MongoDB --番外】错误集合

    1.在第一次安装成功之后,就瞬间发现了如下问题 mongodb无法启动,由于目标计算机积极拒绝,无法连接 解决方法: 这不是mongodb无法启动,是你还没有启动mongodb就来连接使用它了,肯定是 ...

  2. loadrunner处理HTTP重定向请求

    //place this in global.h     int HttpRetCode;  int i=0;  char depthVal[10];  char cTransactName[2000 ...

  3. DLL中传递STL参数(如Vector或者list等)会遇到的问题[转载]

    最近的一个项目中遇到了调用别人的sdk接口(dll库)而传给我的是一个vector指针,用完之后还要我来删除的情况.这个过程中首先就是在我的exe中将其vector指针转为相应指针再获取vector中 ...

  4. css随记02布局

    布局 二栏布局 利用absolute, margin .container { position: relative; } nav { position: absolute; left: 0px; w ...

  5. redis 的使用 ( list列表类型操作)

    list 数据类型 列表类型 list 类型是一个双向操作 从链表的头部或者尾部添加删除元素 list 既可以用作栈 也可以用作队列 list 链表的类型应用场合: 获取最新的 10 个用户的信息 s ...

  6. 树状数组 + 位运算 LA 4013 A Sequence of Numbers

    题目传送门 题意:n个数,两种操作,一是每个数字加x,二是查询& (1 << T) == 1 的个数 分析:因为累加是永远的,所以可以离线处理.树状数组点是c[16][M] 表示数 ...

  7. 二叉搜索树 POJ 2418 Hardwood Species

    题目传送门 题意:输入一大堆字符串,问字典序输出每个字符串占的百分比 分析:二叉搜索树插入,然后中序遍历就是字典序,这里root 被new出来后要指向NULL,RE好几次.这题暴力sort也是可以过的 ...

  8. sqlserver数据库 去除字段中空格,换行符,回车符(使用replace语句)

    SQL中可以使用Replace函数来对某个字段里的某些字符进行替换操作,语法如下: 语法 REPLACE ( original-string, search-string, replace-strin ...

  9. Windows下安装Docker

    放在三年前,你不认识Docker情有可原,但如果现在你还这么说,不好意思,只能说明你OUT了,行动起来吧骚年,很可能你们公司或者你即将要去的公司,或者你想去的公司很可能就会引入Docker,或者已经引 ...

  10. NUC_TeamTEST_B(贪心)

    B - B Time Limit:1000MS     Memory Limit:262144KB     64bit IO Format:%I64d & %I64u Submit Statu ...