文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

怎么搭建Data Guard

2024-04-02 19:55

关注

这篇文章主要讲解了“怎么搭建Data Guard”,文中的讲解内容简单清晰,易于学习与理解,下面请大家跟着小编的思路慢慢深入,一起来研究和学习“怎么搭建Data Guard”吧!

一、 规划

怎么搭建Data Guard

说明:在Data Guard中,

- db_name:主备库必须保持一致;

- db_unique_name:主备库必须不一致;

- service_names和instance_name可以保持一致或不一致。

二、 DG环境要求

1. 硬件和操作系统要求

Data Guard允许主备库有不同的CPU型号,不同的操作系统(例如windows & linux),不同的操作系统位数(32-bit/64-bit)或者不同的数据库位数(32-bit/64-bit)。

2. Oracle软件要求

Data Guard只支持Oracle database企业版,不支持标准版本。

在物理备库中,Oracle主备库的compatiable参数必须保持一致(通常情况下,我们说的Data Guard都是指物理备库)。在逻辑备库中,备库的compatiable必须大于或等于主库参数。

主库可以是单实例库或者RAC,备库也可以是单实例或是RAC。

如果主备库的操作系统一致,那么主备库的存储路径必须保持不同,否则,备库可能会覆盖主库文件。

如果主备库都是RAC,主库使用了ASM和OMF(Oracle managed files)命名管理,那么备库也应该使用ASM和OMF管理。

三、 思路清晰

step1: 主库开启force logging

step2: 备库配置listener.ora文件

step3: 主备库配置tnsnames.ora文件

step4: 主库添加standby logfile

step5: 主备库修改参数文件

step6: RMAN复制数据库

step7: DG检查,应用日志

step8: 开启备库,实时应用日志

四、 准备工作

1. 关闭防火墙(主备库)

# systemctl stop firewalld

# systemctl disable firewalld

2. 禁用selinux(主备库)

# vi /etc/selinux/config

selinux=disabled

3. 检查主库归档设置

SQL> archive log list;

Database log mode              Archive Mode

Automatic archival             Enabled

Archive destination            /archivelog/ORCL

Oldest online log sequence     26

Next log sequence to archive   28

Current log sequence           28

4. 配置/etc/hosts文件(主备库)

# vi /etc/hosts

#Primary IP

172.16.70.178 primary

#Standby IP

172.16.70.179 standby

五、 搭建DG

1. 开启强制日志模式(主库)

SQL> alter database force logging;

2. 配置listener.ora文件(备库)

(Oracle用户)

备库添加静态监听

$ vi $ORACLE_HOME/network/admin/listener.ora

(添加以下内容)

SID_LIST_LISTENER =

 (SID_LIST =

      (SID_DESC =

        (GLOBAL_DBNAME = SBDB)

        (ORACLE_HOME = /u01/app/oracle/product/11.2.0/db_1)

        (SID_NAME = SBDB)

      )

)

开启监听

$ lsnrctl start

3. 修改tnsnames.ora文件(主备库

(主备库一致)

$ vi $ORACLE_HOME/network/admin/tnsnames.ora

ORCL =

  (DESCRIPTION =

    (ADDRESS = (PROTOCOL = TCP)(HOST = primary)(PORT = 1521))

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = ORCL)     

    )

  )

SBDB =

  (DESCRIPTION =

    (ADDRESS = (PROTOCOL = TCP)(HOST = standby)(PORT = 1521))

    (CONNECT_DATA =

      (SERVER = DEDICATED)

      (SERVICE_NAME = SBDB)

    )

  )

tns连通性检测

$ tnsping ORCL

$ tnsping SBDB

4. 主库添加standby logfile;

SQL> select group#,thread#,bytes/1024/1024 M,status from v$log;

SQL> select member from v$logfile;

SQL> alter database add standby logfile '/u01/app/oracle/oradata/ORCL/redo04.log' size 50m;

SQL> alter database add standby logfile '/u01/app/oracle/oradata/ORCL/redo05.log' size 50m;

SQL> alter database add standby logfile '/u01/app/oracle/oradata/ORCL/redo06.log' size 50m;

SQL> alter database add standby logfile '/u01/app/oracle/oradata/ORCL/redo07.log' size 50m;

查看日志组状态

SQL> select group#,status,type,member from v$logfile;

5. 修改参数文件

(主库修改参数)

1) 生成参数文件

SQL> create pfile from spfile;

2) 修改参数文件

$ cd /u01/app/oracle/product/11.2.0/db_1/dbs

$ vi initORCL.ora

添加以下内容:

db_unique_name=ORCL

log_archive_config='dg_config=(ORCL,SBDB)'

log_archive_dest_1='location=/archivelog/ORCL valid_for=(all_logfiles,all_roles) db_unique_name=ORCL'

log_archive_dest_2='service=SBDB lgwr async valid_for=(online_logfiles,primary_roles) db_unique_name=SBDB'

log_archive_dest_state_1=enable

log_archive_dest_state_2=enable

db_file_name_convert='/u01/app/oracle/oradata/SBDB','/u01/app/oracle/oradata/ORCL'

log_file_name_convert='/u01/app/oracle/oradata/SBDB','/u01/app/oracle/oradata/ORCL'

fal_server=SBDB

fal_client=ORCL

standby_file_management=auto    

3) 生成spfile,重启库使参数生效

SQL> shutdown immediate;

SQL> create spfile from pfile;

SQL> startup;

(备库修改)

1) 将主库pfile传到备库

$ scp initORCL.ora standby:$ORACLE_HOME/dbs/initSBDB.ora

2) 修改参数文件

$ cd /u01/app/oracle/product/11.2.0/db_1/dbs

$ vi initSBDB.ora

执行以下命令

:%s/ORCL/AAAA/g

:%s/SBDB/ORCL/g

:%s/AAAA/SBDB/g

最后将db_name修改回ORCL

最后结果如下:

*.audit_file_dest='/u01/app/oracle/admin/SBDB/adump'

*.audit_trail='db'

*.compatible='11.2.0.4.0'

*.control_files='/u01/app/oracle/oradata/SBDB/control01.ctl','/u01/app/oracle/oradata/SBDB/control02.ctl'

*.db_block_size=8192

*.db_domain=''

*.db_name='ORCL'

*.diagnostic_dest='/u01/app/oracle'

*.dispatchers='(PROTOCOL=TCP) (SERVICE=SBDBXDB)'

*.log_archive_dest_1='LOCATION=/archivelog/SBDB'

*.log_archive_format='%t_%s_%r.dbf'

*.memory_target=769654784

*.open_cursors=300

*.processes=150

*.remote_login_passwordfile='EXCLUSIVE'

*.undo_tablespace='UNDOTBS1'

db_unique_name=SBDB

log_archive_config='dg_config=(SBDB,ORCL)'

log_archive_dest_1='location=/archivelog/SBDB valid_for=(all_logfiles,all_roles) db_unique_name=SBDB'

log_archive_dest_2='service=ORCL lgwr async valid_for=(online_logfiles,primary_roles) db_unique_name=ORCL'

log_archive_dest_state_1=enable

log_archive_dest_state_2=enable

db_file_name_convert='/u01/app/oracle/oradata/ORCL','/u01/app/oracle/oradata/SBDB'

log_file_name_convert='/u01/app/oracle/oradata/ORCL','/u01/app/oracle/oradata/SBDB'

fal_server=ORCL

fal_client=SBDB

standby_file_management=auto

3) 备库创建上述目录

$ mkdir -p /u01/app/oracle/admin/SBDB/adump

$ mkdir -p /u01/app/oracle/oradata/SBDB

$ mkdir -p /archivelog/SBDB

4) 备库创建密码文件

$ cd $ORACLE_HOME/dbs/

$ orapwd file=orapwSBDB password=oracle

6. 复制数据库

1) 备库开启到nomount状态

SQL> create spfile from pfile;

SQL> startup nomount;

2)RMAN复制数据库(主库执行)

$ rman target / auxiliary sys/oracle@SBDB

RMAN> duplicate target database for standby from active database;

此时,已经完成了Data Guard搭建部分!

六、 配置ADG

1) 查询主备库状态

(主库)

SQL> col db_unique_name for a15

SQL> select db_unique_name,open_mode,database_role,switchover_status from v$database;

DB_UNIQUE_NAME OPEN_MODE           DATABASE_ROLE    SWITCHOVER_STATUS

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

ORCL               READ WRITE          PRIMARY           FAILED DESTINATION

(备库)

DB_UNIQUE_NAME  OPEN_MODE            DATABASE_ROLE    SWITCHOVER_STATUS

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

SBDB              MOUNTED              PHYSICAL STANDBY SESSIONS ACTIVE

2) 备库应用日志

SQL> alter database recover managed standby database using current logfile disconnect from session;

此时注意检查备库SWITCHOVER_STATUS状态,直到SWITCHOVER_STATUS为NOT ALLOWED为正常。

3) 备库取消应用日志

SQL> alter database recover managed standby database cancel;

4) 开启备库

SQL> alter database open;

5) 备库开启实时应用

SQL> alter database recover managed standby database using current logfile disconnect from session;

6) 再次检查备库状态

SQL> select db_unique_name,open_mode,database_role,switchover_status from v$database;

DB_UNIQUE_NAME   OPEN_MODE              DATABASE_ROLE     SWITCHOVER_STATUS

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

SBDB               READ ONLY WITH APPLY PHYSICAL STANDBY NOT ALLOWED

7) 查看备库进程状态

SQL> select process, pid, status, client_process from v$managed_standby;

PROCESS          PID STATUS       CLIENT_P

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

ARCH           24183 CONNECTED    ARCH

ARCH           24186 CONNECTED    ARCH

ARCH           24188 CLOSING      ARCH

ARCH           24190 CONNECTED    ARCH

RFS            24533 IDLE         LGWR

RFS            24527 IDLE         UNKNOWN

RFS            24529 IDLE         ARCH

RFS            24707 IDLE         UNKNOWN

MRP0           24918 APPLYING_LOG N/A

此时,备库已经是实时应用状态(Active Data Guard)

感谢各位的阅读,以上就是“怎么搭建Data Guard”的内容了,经过本文的学习后,相信大家对怎么搭建Data Guard这一问题有了更深刻的体会,具体使用情况还需要大家实践验证。这里是亿速云,小编将为大家推送更多相关知识点的文章,欢迎关注!

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     813人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     354人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     318人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     435人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     224人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-数据库
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯