使用变量替换批量部署GoldenGate

GoldenGate运行时允许在参数文件中动态指定一个值,即在参数文件中使用一个变量,而不是一个静态的值,当启动OGG进程时,根据环境动态加载此变量的值,达到在不同环境中,通过变量定义,实现多个环境的相同配置部署。对于一对多或多对一的场景,此配置可以降低维护的复杂性。

如下,是一个标准的data pump参数设置:

extract peast

rmthost oelora114, mgrport 15051

rmttrail ./dirdat/pe

passthru

table east.*;

在上面的参数中,我们将目标端主机、端口、远端队列文件前缀等都写死在了配置文件中,但如果我们要从开发环境迁移到测试环境,或继续迁移到生产环境,是否又把参数文件重改一遍呢?这还只是只有几台主机的环境,如果有几十台或上百台呢,维护量和保持一致性就是个大问题。此时,使用参数变量化将可以解决此问题。

下面,我们修改data pump进程为:

extract peast

rmthost ?OGGTarget, mgrport ?OGGListener

rmttrail ?TrailPIEAST

passthru

table ?PIEASTList;

? 表示此单词对应的是一个变量,当OGG启动进程时,OGG将从操作系统的环境变量中获取值,如果操作系统中没有创建这些环境变量,OGG进程将会abended.

下面是本文示例中设置的环境变量:

[oracle@oelora114 ~]$ echo $OGGTarget $OGGListener $TrailPIEAST $PIEASTList

oelora114 15051 ./dirdat/pe east.*

为了让变量替换生效,输入GGSCI进入命令行,如果MGR进程在环境变量设置之前启动,则需要重启MGR进程,这样才能保证环境变量的值能获取到。

GGSCI (oelora114) 3> stop mgr !

Sending STOP request to MANAGER ...

Request processed.

Manager stopped.

GGSCI (oelora114) 4> start mgr

Manager started.

GGSCI (oelora114) 5> start peast

Sending START request to MANAGER ...

EXTRACT P_IEAST starting

GGSCI (oelora114) 6> status peast

EXTRACT P_IEAST: RUNNING

如果查看pump进程的日志报告,可以看到变量已经被替换设置的值:

GGSCI (oelora114) 7> view report peast

***********************************************************************

Oracle GoldenGate Capture for Oracle

Version 12.1.2.0.0 17185003 OGGCORE_12.1.2.0.0_PLATFORMS_130924.1316_FBO

Linux, x64, 64bit (optimized), Oracle 11g on Sep 25 2013 00:44:16

Copyright (C) 1995, 2013, Oracle and/or its affiliates. All rights reserved.

Starting at 2014-04-08 10:00:41

***********************************************************************

Operating System Version:

Linux

Version #1 SMP Wed Jul 17 10:58:36 PDT 2013, Release 2.6.32-400.29.2.el5uek

Node: oelora114

Machine: x86_64

soft limit   hard limit

Address Space Size   :    unlimited    unlimited

Heap Size            :    unlimited    unlimited

File Size            :    unlimited    unlimited

CPU Time             :    unlimited    unlimited

Process id: 11136

Description:

***********************************************************************

**            Running with the following parameters                  **

***********************************************************************

2014-04-08 10:00:41 INFO    OGG-03059 Operating system character set identified as UTF-8.

2014-04-08 10:00:41 INFO    OGG-02695 ANSI SQL parameter syntax is used for parameter parsing.

extract peast

rmthost oelora114, mgrport 15051

?OGGTarget = oelora114

?OGGListener = 15051

rmttrail ./dirdat/pe

?TrailPIEAST = ./dirdat/pe

passthru

table east.*;

?PIEASTList = east.*

在上面的日志中,可以看到变量已经被替换为当前操作系统中的环境变量对应的值。

使用变量替换部署OGG的好处是在大批量的数据复制环境中,可以使用同一参数文件,通过环境变量来适应不同的主机,提升了维护性,也便于批量拷贝部署。

上一篇:iOS 如何创建单例对象


下一篇:如果恨一个程序员,忽悠他去做iOS开发