Oracle数据库dg主备切换

一、数据库切换
1、业务环境:
主库:10.100.0.9
备库:10.100.0.18
空闲:10.100.0.201

目的:主库和备库切换。

1、主库操作--------------------------------------------------------------------------------------------
1.1 关闭主库监听
su - oracle
lsnrctl stop(只在主库操作)

1.2 在主库端检查数据库可切换状态
sqlplus / as sysdba
SQL> select switchover_status from v$database;

如果SWITCHOVER_STATUS 的值为TO STANDBY 表示可以正常切换.

SQL>alter database commit to switchover to physical standby;

Database altered.

如果SWITCHOVER_STATUS 的值为SESSIONS ACTIVE:

SQL> alter database commit to switchover to physical standby with session shutdown;

Database altered.

tailf ORACLE_BASE/admin/ORACLE_SID/bdump/alert_$ORACLE_SID.log 查看日志

2、备库操作---------------------------------------------------------------------------------

2.1这时候到备份库 在备库验证可切换状态

sqlplu / as sysdba

SQL> select switchover_status from v$database;

SWITCHOVER_STATUS

2.22.将目标备库转换为主库
如果SWITCHOVER_STATUS 的值为TO PRIMARY 则:

SQL> alter database commit to switchover to primary;

Database altered.

如果SWITCHOVER_STATUS 的值为SESSIONS ACTIVE 则:

SQL> alter database commit to switchover to primary with session shutdown;

Database altered.

select FILE_NAME,TABLESPACE_NAME,status from dba_temp_files;

tailf ORACLE_BASE/admin/ORACLE_SID/bdump/alert_$ORACLE_SID.log 查看日志

3、修改新备库ip(原主库)----------------------------------------------------------------------------

ping 10.100.0.201

sed -i 's/10.100.0.9/10.100.0.201/g' /etc/sysconfig/network-scripts/ifcfg-bond0
cat /etc/sysconfig/network-scripts/ifcfg-bond0

/etc/init.d/network restart

3.1新主库操作(原备库) 更换ip 此ip 为业务ip

sed -i 's/10.100.0.18/10.100.0.9/g' /etc/sysconfig/network-scripts/ifcfg-bond0
sed -i 's/10.100.0.18/10.100.0.9/g' $ORACLE_HOME/network/admin/listener.ora
cat /etc/sysconfig/network-scripts/ifcfg-bond0

/etc/init.d/network restart

4.重启新主库监听(原备库)-------------------------------------------------------------------------------
lsnrctl stop
lsntctl start

Sql> shutdown immediate;
Sql> startup;

lsnrctl status 如果一直未注册到监听里面,需手动注册一下
Sql>ALTER SYSTEM REGISTER;

至此可以进行业务测试,最后剩余步骤恢复dg 同步状态

二、剩余步骤恢复dg 同步状态
下面进一步恢复dg

1.修改新主备库tnsname.ora文件 (此文件主备库完全一样)
cat << EOF > $ORACLE_HOME/network/admin/tnsnames.ora.bak
DB_WENDING =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 10.100.0.18)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = WENDING)
)
)
DB_PHYSTDBY =
(DESCRIPTION =
(ADDRESS_LIST =
(ADDRESS = (PROTOCOL = TCP)(HOST = 10.100.0.9)(PORT = 1521))
)
(CONNECT_DATA =
(SERVICE_NAME = PHYSTDBY)
)
)
EOF

2.修改新备库监听文件(原主库)
cat << EOF > $ORACLE_HOME/network/admin/listener.ora
SID_LIST_LISTENER =
(SID_LIST =
(SID_DESC =
(SID_NAME = PLSExtProc)
(ORACLE_HOME = /home/oracle/oracle10g/product/10.2.0/db_1)
(PROGRAM = extproc)
)
)

LISTENER =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = 10.100.0.9)(PORT = 1521))
(ADDRESS = (PROTOCOL = IPC)(KEY = EXTPROC0))
)
)
EOF

3、 查看主备 的 /etc/hosts 配置要正确

4,启动新备库库监听 (原主库)

lsnrctl start

重启新备库
Sql>shutdown immediate;
Sql> startup;

5、 新备库执行同步语句
SQL> alter database recover managed standby database disconnect from session;

6、备库查看主备文件同步情况
select sequence#,dest_id,first_time,next_time,archived,applied from v$archived_log order by sequence#

7、主库
set linesize 160 pagesize 999
col destination for a30;
col error for a60;
select status,destination,error from v$archive_dest;

8、主备库都检查
set linesize 160 pagesize 999
col destination for a30;
col error for a60;
select dbid,database_role from vdatabase; select max(sequence#) from varchived_log;
select max(sequence#) from v$archived_log where applied='YES';

9、备库
select process,status,sequence#from v$managed_standby;

10检查新主库脚本

10.1检查rman 备份脚本,以及磁盘挂载目录
10.2检查rman备份监控脚本
备份放在哪台服务器上,监控脚本就放在哪台服务器上。数据量比较大的备份最好放在备库上备份。监控脚本不要放在存储上。
check_rman_backup.sh
10.3检查dg 健康状态脚本
主库是oracle_wending_check.sh
备库是oracle_phystdby_check.sh
有的需要布置check_dg.sh
10.4检查清理归档脚本
主库del_appl_standy_arc_wending.sh
备库del_appl_standy_arc_phystdby.sh

三、新主库启动后如有以下错误,请参考解决方法

一,ORA-30012: undo tablespace 'UNDOTBS1' does not exist or of wrong type
Fri Apr 20 21:17:12 2018

解决方法:
SQL> show parameter undo
NAME TYPE VALUE


undo_management string AUTO
undo_retention integer 900
undo_tablespace string UNDOTBS1

SQL> select name from v$tablespace where name like '%UNDO%';
NAME


UNDOTBS3

sql > create pfile from spfile;

cd $ORACLE_HOME/dbs

vi init$ORACLE_SID.ora
修改undo_tablespace=UNDOTBS3

然后startup mount pfile=ORACLE_HOME/dbs/initORACLE_SID.ora (此处请写绝对路径)

sql > create spfile from pfile;

sql> shutdown immediate;

sql> startup

二,数据库启动后,如应用报如下错误 ORA-01187 ORA-01110,或避免报次错,请预先检查一下临时表空间状态

SQL> select TABLESPACE_NAME,FILE_NAME,STATUS from dba_temp_files;

TABLESPACE_NAME FILE_NAME STATUS


TEMP /oradata/ygdb/temp01.dbf AVAILABLE

如果不是AVAILABLE,请执行以下语句
alter tablespace TEMP add tempfile '/oradata/ygdb/temp02.dbf' size 100m autoextend on;
alter tablespace TEMP drop tempfile '/oradata/ygdb/temp01.dbf';

SQL> alter database tempfile '/oradata/ccod/temp01.dbf' drop;
alter tablespace TEMP add tempfile '/oradata/ccod/temp01.dbf' size 100m autoextend on;

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 206,482评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,377评论 2 382
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 152,762评论 0 342
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,273评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,289评论 5 373
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,046评论 1 285
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,351评论 3 400
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,988评论 0 259
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,476评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,948评论 2 324
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,064评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,712评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,261评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,264评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,486评论 1 262
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,511评论 2 354
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,802评论 2 345

推荐阅读更多精彩内容