奕新集团---单实例到RAC11g生产环境搭建(无图)

本文涉及的产品
云数据库 Tair(兼容Redis),内存型 2GB
Redis 开源版,标准版 2GB
推荐场景:
搭建游戏排行榜
简介: <p>1<span style="font-family:宋体">、</span></p> <p>m1 m2 m3  source<span style="font-family:宋体">端</span></p> <p> </p> <p>2<span style="font-family:宋体">、</span></p> <p>在<span style="font-family:T

1

m1 m2 m3  source

 

2

m1 m2 m3 

 

/etc/hosts

172.16.10.140     source

 

source

添加

#public network

172.16.15.101 m1

172.16.15.102 m2

172.16.15.103 m3

 

#private network

10.11.11.1 m1-pri

10.11.11.2 m2-pri

10.11.11.3 m3-pri

29

#VIP network

172.16.15.104 m1-vip

172.16.15.105 m2-vip

172.16.15.106 m3-vip

 

#GGVIP

172.16.15.107 qr01-vip

 

#racscan network

172.16.15.100 rac-scan

 

3

 

[root@m2 ~]# cd /u01/app/11.2.3/grid/bin/

[root@m2 bin]# ./crsctl stat res -p | grep -ie .network -ie subnet | grep -ie name -ie subnet

NAME=ora.net1.network

USR_ORA_SUBNET=172.16.14.0

[root@m2 bin]# ./appvipcfg create -network=1 -ip=172.16.15.104 -vipname=gg_vip_trg -user=root

./crsctl setperm resource gg_vip_trg -u user:oracle:r-x

 

切换到oracle用户

[root@m2 bin]# su - oracle

[oracle@m2 ~]$ cd /u01/app/11.2.3/grid/bin/

[oracle@m2 bin]$ ./crsctl start resource gg_vip_trg

CRS-2672: Attempting to start 'gg_vip_trg' on 'm2'

CRS-5017: The resource action "gg_vip_trg start" encountered the following error: 

CRS-5005: IP Address: 172.16.15.104 is already in use in the network 留意一下 vip 会不会由此信息提示

. For details refer to "(:CLSN00107:)" in "/u01/app/11.2.3/grid/log/m2/agent/crsd/orarootagent_root/orarootagent_root.log".

CRS-2674: Start of 'gg_vip_trg' on 'm2' failed

CRS-2679: Attempting to clean 'gg_vip_trg' on 'm2'

CRS-2681: Clean of 'gg_vip_trg' on 'm2' succeeded

CRS-2563: Attempt to start resource 'gg_vip_trg' on 'm2' has failed. Will re-retry on 'm3' now.

CRS-2672: Attempting to start 'gg_vip_trg' on 'm3'

CRS-2676: Start of 'gg_vip_trg' on 'm3' succeeded

这里定义一个试试 

要么就是 VIP是自己设定的一个地址

要么就是 VIP是原来主机名字的虚拟VIP----这里我安装的是虚拟VIP试试看不行就换

不用VIP自己设置一个IP地址也可以只要是同一个网段的。

 

 

 

 

 

 

            单实例到RAC单向

前提条件:

1、源库:单实例安装了11.2.3数据库 有Grid、 Oracle 用户

2、目标库:安装了RACscan能连接通。

 

目标RAC

oracle用户

vim .bash_profile

export OGG_HOME=$ORACLE_BASE/ogg

export LD_LIBRARY_PATH=$ORACLE_HOME/lib

export NLS_LANG=AMERICAN_AMERICA.AL32UTF8

 

vim  /etc/hosts

添加源库的IP地址 

172.16.10.140 sdb

源:

vim /etc/hosts

添加 RAC节点下/etc/hosts下的所有内容。

就是主机名 VIP 

 

oracle用户

vim .bash_profile

export  OGG_HOME=$ORACLE_BASE/ogg

exportLD_LIBRARY_PATH=$ORACLE_HOME/lib

添加虚拟VIP分别在RAC 源上

172.16.15.105 qr01-vip

 

RAC节点:

root用户 

cd /u01/app/11.2.3/grid/bin/

./crsctl stat res -p | grep -ie .network -ie subnet | grep -ie name -ie subnet

./appvipcfg create -network=1 -ip=172.16.15.107 -vipname=gg_vip_trg -user=root

 

./crsctl setperm resource gg_vip_trg -u user:oracle:r-x

 

oracle用户:

cd /u01/app/11.2.3/grid/bin

./crsctl start resource gg_vip_trg

./crsctl status resource gg_vip_trg

 

源上:

[oracle@host01 ogg]$ ping qr01-vip 

 

rac上:

 

tnsping mes 

 

为安装GG做准备。

 

源:

sqlplus / as sysdba

SELECT log_mode, force_logging, supplemental_log_data_min FROM v$database;

CREATE USER oggadm1 IDENTIFIED BY pswd1a;

GRANT dba TO oggadm1;

exec

DBMS_GOLDENGATE_AUTH.GRANT_ADMIN_PRIVILEGE('OGGADM1','capture',TRUE);

 

RAC上:

select log_mode,force_logging,supplemental_log_data_min from v$database;

NO NO

接着

 

crs_stop ora.mes.db  关闭数据库。

 

节点一 只是需要在一个节点做就可以了

sqlplus / as sysdba

startup mount 

alter database archivelog;

alter database open;

alter system set log_archive_dest_state_1='location=/home/oracle/arch' scope=spfile;

alter system set log_archive_dest_1 ='location=+DATA/ARC1' scope=spfile sid='orcl1';

alter system set log_archive_dest_1 ='location=+DATA/ARC2' scope=spfile sid='orcl2';

show parameter db_recovery

 

ALTER DATABASE ADD SUPPLEMENTAL LOG DATA;

ALTER DATABASE FORCE LOGGING;

ALTER SYSTEM SWITCH LOGFILE;

select log_mode,force_logging,supplemental_log_data_min from v$database;

commit;

shutdown immediate 

 

源上:

对照上面的做,一个一个来包括源数据库也是一样的。

 

节点一 源上 startup

show parameter name

 

RAC上:

CREATE USER oggadm2 IDENTIFIED BY pswd2a;

exec

DBMS_GOLDENGATE_AUTH.GRANT_ADMIN_PRIVILEGE ('OGGADM2','capture',TRUE);

 

 

 

-----------------------------从下面开始我准备创建ACFS集群文件系统来代替DBFS步骤

sqlplus / as sysasm

五:创建卷并格式化成acfs集群文件系统并挂载

SQL> alter diskgroup data add volume acfsvol size 1G; 

Diskgroup altered. 

 

[root@rac1 ~]# mkdir /sharedisk 

[root@rac2 ~]# mkdir /sharedisk 

[root@rac1 ~]# /sbin/mkfs -t acfs -n ACFSVOL1 /dev/asm/acfsvol-53  

mkfs.acfs: version                   = 11.2.0.3.0 

mkfs.acfs: on-disk version           = 39.0 

10 mkfs.acfs: volume                    = /dev/asm/acfsvol-53 

11 mkfs.acfs: volume size               = 1073741824 

12 mkfs.acfs: Format complete. 

13  

14 [root@rac1 ~]# /sbin/acfsutil registry -a -f /dev/asm/acfsvol-53 /sharedisk/ 

15 acfsutil registry: mount point /sharedisk successfully added to Oracle Registry 

16  

17 [root@rac1 ~]# mount.acfs -o all 

18 [root@rac1 ~]# df -h 

19 Filesystem            Size  Used Avail Use% Mounted on 

20 /dev/mapper/VolGroup00-LogVol00 

21                        93G   19G   70G  21% / 

22 /dev/sda1             190M   17M  165M   9% /boot 

23 tmpfs                 2.0G  1.2G  807M  60% /dev/shm 

24 /dev/asm/acfsvol-53   1.0G   39M  986M   4% /sharedisk 

25  

26 [root@rac2 ~]# mount.acfs -o all 

27 [root@rac2 ~]# df -h 

28 Filesystem            Size  Used Avail Use% Mounted on 

29 /dev/mapper/VolGroup00-LogVol00 

30                        93G   12G   77G  14% / 

31 /dev/sda1              99M   17M   78M  18% /boot 

32 tmpfs                 2.0G  1.2G  807M  60% /dev/shm 

33 /dev/asm/acfsvol-53   1.0G   73M  952M   8% /sharedisk 

34  

35 [root@rac1 ~]# /sbin/acfsutil info fs  

36 /sharedisk 

37     ACFS Version: 11.2.0.3.0 

38     flags:        MountPoint,Available 

39     mount time:   Wed Feb 20 12:11:52 2013 

40     volumes:      1 

41     total size:   1073741824 

42     total free:   998002688 

43     primary volume: /dev/asm/acfsvol-53 

44         label:                 ACFSVOL1 

45         flags:                 Primary,Available,ADVM 

46         on-disk version:       39.0 

47         allocation unit:       4096 

48         major, minor:          252, 27137 

49         size:                  1073741824 

50         free:                  998002688 

51         ADVM diskgroup         DATA 

52         ADVM resize increment: 33554432 

53         ADVM redundancy:       unprotected 

54         ADVM stripe columns:   4 

55         ADVM stripe width:     131072 

56     number of snapshots:  0 

57     snapshot space usage: 0 

58     replication status: DISABLED 

 

[root@m1 mnt]# chown oracle.oinstall /acfs/ -R

RAC节点:

[oracle@m1 ~]$ echo $OGG_HOME

/u01/oracle/ogg

[oracle@m1 ~]$ cd $ORACLE_HOME

[oracle@m1 db]$ pwd

/u01/oracle/11.2.3/db

[oracle@m1 db]$ cd $ORACLE_BASE

[oracle@m1 oracle]$ pwd

/u01/oracle

[oracle@m1 oracle]$ mkdir ogg

[oracle@m1 oracle]$ cd $OGG_HOME

[oracle@m1 ogg]$ pwd

/u01/oracle/ogg

[oracle@m1 ogg]$  使用ftp上传数据到这上面 ogg112101_fbo_ggs_Linux_x64_ora11g_64bit

unzip ogg112101_fbo_ggs_Linux_x64_ora11g_64bit

 tar -xvf fbo_ggs_Linux_x64_ora11g_64bit.tar 

 

源上同样建立ogg目录。

 

RAC上:

 

cd $OGG_HOME

cp  ./dirprm/jagent.prm jagent.backup 

rm -rf dirprm 

 

mkdir /acfs/acfs_sm/ogg -p

mkdir /acfs/acfs_sm/ogg/dirprm

mkdir /acfs/acfs_sm/ogg/dirpcs

mkdir /acfs/acfs_sm/ogg/dirchk

 

mkdir /acfs/acfs_big/ogg -p 

mkdir /acfs/acfs_big/ogg/dirdat

ln -s  /acfs/acfs_sm/ogg/dirprm $OGG_HOME/dirprm

ln -s  /acfs/acfs_sm/ogg/dirpcs $OGG_HOME/dirpcs

ln -s  /acfs/acfs_sm/ogg/dirchk $OGG_HOME/dirchk

 

./ggsci

create subdirs

GGSCI (m1) 2> exit

[oracle@m1 ogg]$ mv jagent.prm.bak /acfs/acfs_sm/ogg/dirprm/jagent.prm

[oracle@m1 ogg]$ cd dirprm/

[oracle@m1 dirprm]$ ll

total 4

-rwxr-x--- 1 oracle oinstall 53 Dec 12 14:23 jagent.prm

[oracle@m1 dirprm]$ pwd

/u01/oracle/ogg/dirprm

 

其他节点上:

 

cd $OGG_HOME

cp  ./dirprm/jagent.prm jagent.backup 

rm -rf dirprm 

 

ln -s  /acfs/acfs_sm/ogg/dirprm $OGG_HOME/dirprm

ln -s  /acfs/acfs_sm/ogg/dirpcs $OGG_HOME/dirpcs

ln -s  /acfs/acfs_sm/ogg/dirchk $OGG_HOME/dirchk

 

 

 

./ggsci

create subdirs

GGSCI (m1) 2> exit

[oracle@m1 ogg]$ mv jagent.prm.bak /acfs/acfs_sm/ogg/dirprm/jagent.prm

[oracle@m1 ogg]$ cd dirprm/

[oracle@m1 dirprm]$ ll

total 4

-rwxr-x--- 1 oracle oinstall 53 Dec 12 14:23 jagent.prm

[oracle@m1 dirprm]$ pwd

/u01/oracle/ogg/dirprm

 

一定要按照上面的步骤来。

源上:

cd $OGG_HOME

vim startup.oby 

 

DBLogin UserID oggadm1@sdb, Password pswd1a

Start Mgr

Info Mgr

Info CheckpointTable 

exit每次退出去之后,就需要dblogin)

 

vim GLOBALS (大写)不要写成小写

CheckpointTable oggadm1.oggchkpt

 

./gggsci

create subdirs

 

edit param mgr

Port 15001

PurgeOldExtracts ./dirdat/*, UseCheckpoints

 

Obey startup.oby

 

RAC节点上:

cd $OGG_HOME

 

vim startup.oby

 

DBLogin UserID oggadm2@mes, Password pswd2a

Start Mgr

Info Mgr

Info CheckpointTable

 

vim GLOBALS

CheckpointTable oggadm2.oggchkpt

/ggsci

 

edit param mgr

Port 15002

Autostart ER *

AutoRestart ER *

PurgeOldExtracts ./dirdat/*, UseCheckpoints

 

obey startup.oby

exit

 

其他节点上:

 

vim startup.oby

 

DBLogin UserID oggadm2@mes, Password pswd2a

Start Mgr

Info Mgr

Info CheckpointTable

 

vim GLOBALS

CheckpointTable oggadm2.oggchkpt

 

添加数据测试:

 

源上:

GGSCI (sdb) 10> Add TranData hr.regions

 

Logging of supplemental redo data enabled for table HR.REGIONS.

Info TranData hr.*

 

源上:

 

edit param eregab

 

Extract eregab             

ExtTrail ./dirdat/aa            

UserID oggadm1@sdb, Password pswd1a                        

Table hr.regions;

 

edit param pregab

Extract pregab

RmtHost qr01-vip, MgrPort 15002, Compress   

RmtTrail /acfs/acfs_big/ogg/dirdat/ab                     

Passthru                                                      

Table hr.regions;

 

Add Extract eregab, TranLog, Begin Now

Add ExtTrail ./dirdat/aa, Extract eregab, Megabytes 2

 

Add Extract pregab, ExtTrailSource ./dirdat/aa

 

Add RmtTrail /acfs/acfs_big/ogg/dirdat/ab,Extract pregab, Megabytes 2

 

节点一上:

 

 

edit param rregab

Replicat rregab

UserID oggadm2@mes, password pswd2a   

AssumeTargetDefs                                           

DiscardFile dirrpt/rsalesab.dsc, Append                    

Map hr.*, Target hr.*; 

 

Add Replicat rregab,ExtTrail /acfs/acfs_big/ogg/dirdat/ab

Add CheckpointTable

 

start *

info all 

源上:

cd $OGG_HOME

./ggsci 

obey startup.oby

Add CheckpointTable

info all

start *

exit

 

源:

alter user hr identified by hr account unlock;

SQL> insert into regions values(10,'Polar');

SQL> insert into regions values(11,'Oceans');

SQL> commit;

 

 

RAC

hr用户
SELECT * FROM regions;

ll /acfs/acfs_big/ogg/dirdat/

ll /acfs/acfs_sm/ogg/dirchk/

total 8

-rw-rw-r-- 1 oracle oinstall 4096 Dec 12 17:24 RREGAB.cpr

-rw-rw-r-- 1 oracle oinstall   24 Dec 12 17:24 RREGAB.cps

 

 

 

 

 

假如源上 ogg坏了 怎么办?

 

ggsicstop * 

stop mgr

rm -rf  $ORACLE_BASE/ogg

上传文件 解压缩 

 

 

----------------上面所有步骤配置出来的只是 DML操作

 下面 DDL操作。。。。。。。。。。。。。

总结一下 : GGVIP都可以不要。为什么呢,可以填写m1 IPVIP地址。除此之外,其他都不行,包括172.16.15.107

 

 

源上:

[root@sdb ~]# su - oracle

[oracle@sdb ~]$ cd /u01/oracle/ogg/

[oracle@sdb ogg]$ cat startup.oby 

DBLogin UserID oggadm1@sdb, Password pswd1a

Start Mgr

Info Mgr

Info CheckpointTable

[oracle@sdb ogg]$ sqlplus / as sysdba

 

SQL*Plus: Release 11.2.0.3.0 Production on Sun Dec 15 21:15:46 2013

 

Copyright (c) 1982, 2011, Oracle.  All rights reserved.

 

 

Connected to:

Oracle Database 11g Enterprise Edition Release 11.2.0.3.0 - 64bit Production

With the Partitioning, Oracle Label Security, OLAP, Data Mining,

Oracle Database Vault and Real Application Testing options

 

SQL> grant execute on utl_file to oggadm1

 

GGSCI (sdb) 7> view params ./GLOBALS

 

CheckpointTable oggadm1.oggchkpt

 

 

GGSCI (sdb) 8> edit param ./GLOBALS

CheckpointTable oggadm1.oggchkpt

ggschema oggadm1

ogg目录下

SQL> sho user

USER is "SYS"

SQL> @marker_setup.sql

 

SQL> alter system set recyclebin=off DEFERRED;

 

System altered.

 

SQL> shutdown immediate

QL> startup

SQL> show parameter recyclebin;

 

NAME      TYPE  VALUE

------------------------------------ ----------- ------------------------------

recyclebin

     string  OFF

 

@ddl_setup.sql 

@role_setup.sql

grant ggs_ggsuser_role to oggadm1;

@ddl_enable.sql

@?/rdbms/admin/dbmspool.sql

[root@sdb ~]# find / -name dbmspool.sql

/u01/app/grid/11.2.3/rdbms/admin/dbmspool.sql

/u01/oracle/11.2.3/rdbms/admin/dbmspool.sql

[root@sdb ~]# 

SQL> @/u01/oracle/11.2.3/rdbms/admin/dbmspool.sql

@ddl_pin.sql oggadm1

 

edit param eregab

setenv (NLS_LANG=AMERICAN_AMERICA.AL32UTF8) 

ddl include all

 

edit param pregab

setenv (NLS_LANG=AMERICAN_AMERICA.AL32UTF8) 

 

RAC上:

 

edit param rregab

setenv (NLS_LANG=AMERICAN_AMERICA.AL32UTF8)

ddl include all

ddlerror default ignore retryop maxretries 3 retrydelay 5

HANDLECOLLISIONS

相关实践学习
基于Redis实现在线游戏积分排行榜
本场景将介绍如何基于Redis数据库实现在线游戏中的游戏玩家积分排行榜功能。
云数据库 Redis 版使用教程
云数据库Redis版是兼容Redis协议标准的、提供持久化的内存数据库服务,基于高可靠双机热备架构及可无缝扩展的集群架构,满足高读写性能场景及容量需弹性变配的业务需求。 产品详情:https://www.aliyun.com/product/kvstore &nbsp; &nbsp; ------------------------------------------------------------------------- 阿里云数据库体验:数据库上云实战 开发者云会免费提供一台带自建MySQL的源数据库&nbsp;ECS 实例和一台目标数据库&nbsp;RDS实例。跟着指引,您可以一步步实现将ECS自建数据库迁移到目标数据库RDS。 点击下方链接,领取免费ECS&amp;RDS资源,30分钟完成数据库上云实战!https://developer.aliyun.com/adc/scenario/51eefbd1894e42f6bb9acacadd3f9121?spm=a2c6h.13788135.J_3257954370.9.4ba85f24utseFl
目录
相关文章
Oracle RAC迁移到单实例DB
这篇文章记录Oracle RAC通过RMAN备份如何迁移到单机DB,文章中描述了几个容易出错的地方,如下:    ①RAC到单机redo文件位置处理    ②RAC多个UNDO处理    ③RAC到单机临时表空间处理下面开始文章正文。
8264 0
|
存储 Oracle 关系型数据库