首页 > 数据库技术 > 详细

利用存储级的复制技术将一个ASM数据库快速clone到目标环境

时间:2015-07-25 02:15:27      阅读:297      评论:0      收藏:0      [点我收藏+]

生产库是建在ASM上的两节点RAC,测试库是单节点的安装了Oracle restart,版本和生产一样同为11.2.0.3
现使用存储级的复制软件将生产库的所有DG拷贝到测试库所在的磁阵,以快速构建出一个测试环境
以下记录了存储复制完成后,测试库搭建的全过程:

如果我们安装Oracle Restart环境时选择的是"Install Oracle Grid Infrastructure for a Standalone software only",那么安装完后还要进行如下配置,如果已经配置好了ASM那么直接进入"2、启动ASM实例,Mount磁盘组"

/////////////////

// 1、oracle restart安装后的配置
///////////////// 

###root用户执行,其中ORACLE_HOME是grid用户下的变量

export DISPLAY=10.10.176.140:0.0
export ORACLE_HOME=/oracle/app/grid
$ORACLE_HOME/perl/bin/perl -I $ORACLE_HOME/perl/lib -I $ORACLE_HOME/crs/install $ORACLE_HOME/crs/install/roothas.pl

Using configuration parameter file: /oracle/app/grid/crs/install/crsconfig_params
Creating trace directory
User ignored Prerequisites during installation
LOCAL ADD MODE
Creating OCR keys for user ‘grid‘, privgrp ‘oinstall‘..
Operation successful.
LOCAL ONLY MODE
Successfully accumulated necessary OCR keys.
Creating OCR keys for user ‘root‘, privgrp ‘system‘..
Operation successful.
CRS-4664: Node qc26702a successfully pinned.
Adding Clusterware entries to inittab

qc26702a     2015/07/22 16:35:26     /oracle/app/grid/cdata/qc26702a/backup_20150722_163526.olr
Successfully configured Oracle Grid Infrastructure for a Standalone Server


###可以看到基础资源已经注册到了oracle restart环境

grid@qc26702a:/home/grid>crsctl status res -t
--------------------------------------------------------------------------------
NAME           TARGET  STATE        SERVER                   STATE_DETAILS      
--------------------------------------------------------------------------------
Local Resources
--------------------------------------------------------------------------------
ora.ons
               OFFLINE OFFLINE      qc26702a                                    
--------------------------------------------------------------------------------
Cluster Resources
--------------------------------------------------------------------------------
ora.cssd
      1        OFFLINE OFFLINE                                                  
ora.diskmon
      1        OFFLINE OFFLINE                                                  
ora.evmd
      1        ONLINE  ONLINE       qc26702a 
     
###继续进行配置,这步主要是更新oracle Inventory,以Grid用户执行
su - grid
export DISPLAY=10.10.176.140:0.0  
$ORACLE_HOME/oui/bin/runInstaller -updateNodeList ORACLE_HOME=$ORACLE_HOME -defaultHomeName CLUSTER_NODES= CRS=TRUE     
Starting Oracle Universal Installer...

Starting Oracle Universal Installer...

Checking swap space: must be greater than 500 MB.   Actual 16384 MB    Passed
The inventory pointer is located at /etc/oraInst.loc
The inventory is located at /oracle/app/oraInventory
‘UpdateNodeList‘ was successful.

###使用asmca配置ASM实例,并启动ASM instance
创建过程中必须指定一块盘创建dg用于存放spfile,注意这块磁盘不能是BCV的目标磁盘,否则下次同步时信息会丢失


###ASM实例创建后检查ora.SPDG.dg(包含spfile的diskgroup)、ora.asm、ora.cssd、ora.evmd四个资源应该处于online

grid@qc26702a:/home/grid>crsctl status res -t
--------------------------------------------------------------------------------
NAME           TARGET  STATE        SERVER                   STATE_DETAILS      
--------------------------------------------------------------------------------
Local Resources
--------------------------------------------------------------------------------
ora.SPDG.dg
               ONLINE  ONLINE       qc26702a                                       
ora.asm
               ONLINE  ONLINE       qc26702a                 Started            
ora.ons
               OFFLINE OFFLINE      qc26702a                                    
--------------------------------------------------------------------------------
Cluster Resources
--------------------------------------------------------------------------------
ora.cssd
      1        ONLINE  ONLINE       qc26702a                                    
ora.diskmon
      1        OFFLINE OFFLINE                                                  
ora.evmd
      1        ONLINE  ONLINE       qc26702a
     
/////////////////
// 2、启动ASM实例,Mount磁盘组
/////////////////    
  

###连接ASM实例,使用asmcmd的lsdg命令能看到刚才创建的存放spfile的DG
grid@qc26702a:/home/grid>export ORACLE_SID=+ASM
grid@qc26702a:/home/grid>asmcmd
ASMCMD> lsdg
State    Type    Rebal  Sector  Block       AU  Total_MB  Free_MB  Req_mir_free_MB  Usable_file_MB  Offline_disks  Voting_files  Name
MOUNTED  EXTERN  N         512   4096  1048576     46477    46418                0           46418              0             N  SPDG/

###调整ASM初始化参数重启ASM instance
alter system set asm_diskstring=‘/dev/rhdiskpower*‘ scope=both;

srvctl stop asm -o immediate
srvctl start asm    
     
###修改磁盘权限
chown oracle:dba /dev/rhdiskpower*
chmod 660 /dev/rhdiskpower*


###使用kfod确认这磁盘信息都能被oracle或者grid用户准确读到

grid@qc26702a:/home/grid>kfod asm_diskstring=‘/dev/rhdiskpower*‘ disks=all
--------------------------------------------------------------------------------
 Disk          Size Path                                     User     Group  
================================================================================
   1:      46477 Mb /dev/rhdiskpower0                        oracle   dba    
   2:      46477 Mb /dev/rhdiskpower1                        oracle   dba    
   3:      46477 Mb /dev/rhdiskpower10                       oracle   dba    
   4:      46477 Mb /dev/rhdiskpower11                       oracle   dba    
   5:      46477 Mb /dev/rhdiskpower12                       oracle   dba    
   6:      46477 Mb /dev/rhdiskpower13                       oracle   dba    
   7:      46477 Mb /dev/rhdiskpower14                       oracle   dba    
   8:      46477 Mb /dev/rhdiskpower15                       oracle   dba    
   9:      46477 Mb /dev/rhdiskpower16                       oracle   dba    
  10:      46477 Mb /dev/rhdiskpower17                       oracle   dba    
  11:      46477 Mb /dev/rhdiskpower18                       oracle   dba    
  12:      46477 Mb /dev/rhdiskpower19                       oracle   dba    
  13:      46477 Mb /dev/rhdiskpower2                        oracle   dba    
  14:      46477 Mb /dev/rhdiskpower20                       oracle   dba    
  15:      46477 Mb /dev/rhdiskpower21                       oracle   dba    
  16:      46477 Mb /dev/rhdiskpower22                       oracle   dba    
  17:      46477 Mb /dev/rhdiskpower23                       oracle   dba    
  18:      46477 Mb /dev/rhdiskpower24                       oracle   dba    
  19:      46477 Mb /dev/rhdiskpower25                       oracle   dba    
  20:      46477 Mb /dev/rhdiskpower26                       oracle   dba    
  21:      46477 Mb /dev/rhdiskpower27                       oracle   dba    
  22:      46477 Mb /dev/rhdiskpower28                       oracle   dba    
  23:      46477 Mb /dev/rhdiskpower29                       oracle   dba    
  24:      46477 Mb /dev/rhdiskpower3                        oracle   dba    
  25:      46477 Mb /dev/rhdiskpower30                       oracle   dba    
  26:      46477 Mb /dev/rhdiskpower31                       oracle   dba    
  27:      46477 Mb /dev/rhdiskpower32                       oracle   dba    
  28:      46477 Mb /dev/rhdiskpower33                       oracle   dba    
  29:      46477 Mb /dev/rhdiskpower34                       oracle   dba    
  30:      46477 Mb /dev/rhdiskpower35                       oracle   dba    
  31:      46477 Mb /dev/rhdiskpower36                       oracle   dba    
  32:      46477 Mb /dev/rhdiskpower37                       oracle   dba    
  33:      46477 Mb /dev/rhdiskpower38                       oracle   dba    
  34:      46477 Mb /dev/rhdiskpower39                       oracle   dba    
  35:      46477 Mb /dev/rhdiskpower4                        oracle   dba    
  36:      46477 Mb /dev/rhdiskpower40                       oracle   dba    
  37:      46477 Mb /dev/rhdiskpower41                       oracle   dba    
  38:      46477 Mb /dev/rhdiskpower42                       oracle   dba    
  39:      46477 Mb /dev/rhdiskpower43                       oracle   dba    
  40:      46477 Mb /dev/rhdiskpower5                        oracle   dba    
  41:      46477 Mb /dev/rhdiskpower6                        oracle   dba    
  42:      46477 Mb /dev/rhdiskpower7                        oracle   dba    
  43:      46477 Mb /dev/rhdiskpower8                        oracle   dba    
  44:      46477 Mb /dev/rhdiskpower9                        oracle   dba    
--------------------------------------------------------------------------------
ORACLE_SID ORACLE_HOME                                                         
================================================================================
      +ASM /oracle/app/grid           
                                        

###连接ASM instance,mount diskgroup
export ORACLE_SID=+ASM
sqlplus ‘/as sysasm‘
alter diskgroup AJXDG1 mount;
alter diskgroup AJXDG2 mount;

注:dg名称可以通过kfed命令得到:
grid@qc26702a:/home/grid>kfed read /dev/rhdiskpower21 | grep grpname
kfdhdb.grpname:                  AJXDG1 ; 0x048: length=6


###检查diskgroup & disk状态

set linesize 200 pagesize 80
column path format a45
column name format a20
column failgroup format a15
select group_number, disk_number, mount_status, header_status, state, failgroup, name, path from v$asm_disk_stat;
GROUP_NUMBER DISK_NUMBER MOUNT_S HEADER_STATU STATE    FAILGROUP       NAME                 PATH
------------ ----------- ------- ------------ -------- --------------- -------------------- ---------------------------------------------
           1           0 CACHED  MEMBER       NORMAL   SPDG_0000       SPDG_0000            /dev/rhdiskpower0
           2           0 CACHED  MEMBER       NORMAL   AJXDG1_0000     AJXDG1_0000          /dev/rhdiskpower12
           2           1 CACHED  MEMBER       NORMAL   AJXDG1_0001     AJXDG1_0001          /dev/rhdiskpower13
           2           2 CACHED  MEMBER       NORMAL   AJXDG1_0002     AJXDG1_0002          /dev/rhdiskpower14
           2           3 CACHED  MEMBER       NORMAL   AJXDG1_0003     AJXDG1_0003          /dev/rhdiskpower15
           2           4 CACHED  MEMBER       NORMAL   AJXDG1_0004     AJXDG1_0004          /dev/rhdiskpower16
           2           5 CACHED  MEMBER       NORMAL   AJXDG1_0005     AJXDG1_0005          /dev/rhdiskpower17
           2           6 CACHED  MEMBER       NORMAL   AJXDG1_0006     AJXDG1_0006          /dev/rhdiskpower18
           2           7 CACHED  MEMBER       NORMAL   AJXDG1_0007     AJXDG1_0007          /dev/rhdiskpower19
           2           8 CACHED  MEMBER       NORMAL   AJXDG1_0008     AJXDG1_0008          /dev/rhdiskpower20
           2           9 CACHED  MEMBER       NORMAL   AJXDG1_0009     AJXDG1_0009          /dev/rhdiskpower21
           2          10 CACHED  MEMBER       NORMAL   AJXDG1_0010     AJXDG1_0010          /dev/rhdiskpower22
           2          11 CACHED  MEMBER       NORMAL   AJXDG1_0011     AJXDG1_0011          /dev/rhdiskpower23
           2          12 CACHED  MEMBER       NORMAL   AJXDG1_0012     AJXDG1_0012          /dev/rhdiskpower24
           2          13 CACHED  MEMBER       NORMAL   AJXDG1_0013     AJXDG1_0013          /dev/rhdiskpower25
           2          14 CACHED  MEMBER       NORMAL   AJXDG1_0014     AJXDG1_0014          /dev/rhdiskpower26
           2          15 CACHED  MEMBER       NORMAL   AJXDG1_0015     AJXDG1_0015          /dev/rhdiskpower27
           3           0 CACHED  MEMBER       NORMAL   AJXDG2_0000     AJXDG2_0000          /dev/rhdiskpower28
           3           1 CACHED  MEMBER       NORMAL   AJXDG2_0001     AJXDG2_0001          /dev/rhdiskpower29
           3           2 CACHED  MEMBER       NORMAL   AJXDG2_0002     AJXDG2_0002          /dev/rhdiskpower30
           3           3 CACHED  MEMBER       NORMAL   AJXDG2_0003     AJXDG2_0003          /dev/rhdiskpower31
           3           4 CACHED  MEMBER       NORMAL   AJXDG2_0004     AJXDG2_0004          /dev/rhdiskpower32
           3           5 CACHED  MEMBER       NORMAL   AJXDG2_0005     AJXDG2_0005          /dev/rhdiskpower33
           3           6 CACHED  MEMBER       NORMAL   AJXDG2_0006     AJXDG2_0006          /dev/rhdiskpower34
           3           7 CACHED  MEMBER       NORMAL   AJXDG2_0007     AJXDG2_0007          /dev/rhdiskpower35
           3           8 CACHED  MEMBER       NORMAL   AJXDG2_0008     AJXDG2_0008          /dev/rhdiskpower36
           3           9 CACHED  MEMBER       NORMAL   AJXDG2_0009     AJXDG2_0009          /dev/rhdiskpower37
           3          10 CACHED  MEMBER       NORMAL   AJXDG2_0010     AJXDG2_0010          /dev/rhdiskpower38
           3          11 CACHED  MEMBER       NORMAL   AJXDG2_0011     AJXDG2_0011          /dev/rhdiskpower39
           3          12 CACHED  MEMBER       NORMAL   AJXDG2_0012     AJXDG2_0012          /dev/rhdiskpower40
           3          13 CACHED  MEMBER       NORMAL   AJXDG2_0013     AJXDG2_0013          /dev/rhdiskpower41
           3          14 CACHED  MEMBER       NORMAL   AJXDG2_0014     AJXDG2_0014          /dev/rhdiskpower42
           3          15 CACHED  MEMBER       NORMAL   AJXDG2_0015     AJXDG2_0015          /dev/rhdiskpower43

SQL> select group_number, name, state, type, total_mb, free_mb from v$asm_diskgroup_stat;

GROUP_NUMBER NAME                 STATE       TYPE     TOTAL_MB    FREE_MB
------------ -------------------- ----------- ------ ---------- ----------
           1 SPDG                 MOUNTED     EXTERN      46477      46418
           2 AJXDG1               MOUNTED     EXTERN     743632     350106
           3 AJXDG2               MOUNTED     EXTERN     743632     354227
          
###检查CRS资源组状态
crsctl status res -t
--------------------------------------------------------------------------------
NAME           TARGET  STATE        SERVER                   STATE_DETAILS      
--------------------------------------------------------------------------------
Local Resources
--------------------------------------------------------------------------------
ora.AJXDG1.dg
               ONLINE  ONLINE       qc26702a                                    
ora.AJXDG2.dg
               ONLINE  ONLINE       qc26702a                                    
ora.SPDG.dg
               ONLINE  ONLINE       qc26702a                                    
ora.asm
               ONLINE  ONLINE       qc26702a                 Started            
ora.ons
               OFFLINE OFFLINE      qc26702a                                    
--------------------------------------------------------------------------------
Cluster Resources
--------------------------------------------------------------------------------
ora.cssd
      1        ONLINE  ONLINE       qc26702a                                    
ora.diskmon
      1        OFFLINE OFFLINE                                                  
ora.evmd
      1        ONLINE  ONLINE       qc26702a    
 

/////////////////
// 3、启动数据库实例
/////////////////
###将参数文件创建到dg的spfile
***initajxbcv1.ora内容
sga_target=500M
db_block_size=8192
db_name=shajx
instance_name=ajxbcv1
control_files=‘+AJXDG1/sys/control01.ctl‘,‘+AJXDG2/sys/control02.ctl‘
cluster_database=FALSE

***create spfile from pfile
sqlplus ‘/as sysdba‘
startup mount;
create spfile=‘+SPDG‘ from pfile=‘$ORACLE_HOME/dbs/initajxbcv1.ora‘


###找到spfile的存放路径,将此路径放到初始化参数文件

ASMCMD> pwd
+spdg/SHAJX/PARAMETERFILE
ASMCMD> ls -l
Type           Redund  Striped  Time             Sys  Name
PARAMETERFILE  UNPROT  COARSE   JUL 22 19:00:00  Y    spfile.257.885757443

###初始化参数文件initajxbcv1.ora调整为只包含如下内容
spfile=‘+spdg/SHAJX/PARAMETERFILE/spfile.257.885757443‘


###将数据库资源添加到oracle restart环境,启动数据库

srvctl add database -d shajx -o $ORACLE_HOME -i ajxbcv1 

srvctl start database -d shajx

###检查db资源已经online
grid@qc26702a:/home/grid>crsctl status res -t
--------------------------------------------------------------------------------
NAME           TARGET  STATE        SERVER                   STATE_DETAILS      
--------------------------------------------------------------------------------
Local Resources
--------------------------------------------------------------------------------
ora.AJXDG1.dg
               ONLINE  ONLINE       qc26702a                                    
ora.AJXDG2.dg
               ONLINE  ONLINE       qc26702a                                    
ora.SPDG.dg
               ONLINE  ONLINE       qc26702a                                    
ora.asm
               ONLINE  ONLINE       qc26702a                 Started            
ora.ons
               OFFLINE OFFLINE      qc26702a                                    
--------------------------------------------------------------------------------
Cluster Resources
--------------------------------------------------------------------------------
ora.cssd
      1        ONLINE  ONLINE       qc26702a                                    
ora.diskmon
      1        OFFLINE OFFLINE                                                  
ora.evmd
      1        ONLINE  ONLINE       qc26702a                                    
ora.shajx.db
      1        ONLINE  ONLINE       qc26702a                 Open               

 

利用存储级的复制技术将一个ASM数据库快速clone到目标环境

原文:http://blog.itpub.net/53956/viewspace-1744963/

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!