How to handle ddl in GoldenGate environment without ddl replication?

Question:gg only config to replicate dml, when source has some ddl changes, how to handle in source and target?

Answer:
GoldenGate capture the dml changes only by default,if you have made any changes in DDL structure,then stop the extract and replicat process and make changes in DDL structure and restart the extract and replicat process,then only extract can be able to capture the changes done at DDL structure.

It is advisible that stop extract,pump and replicat process make changes in the DDL and restart the extract,pump and replicat.
The above suggested procedure will not make any impact in DDL replication.

Also you can follow the below procedure
1. stop extract
2. stop data pump
3. there are lag in replicat, so replicat still running to reduce lag
4. do ddl in source, when replicat is running
5. stop replicat untill lag=0
6.do ddl in target
7.start extract and pump and replicat

Question:After do ddl in source, whether need to do delete and re-add the trandata on the table which is been changed?

Answer:
yes,you are correct,After doing DDL changes,you need to do delete and re-add the trandata on the table which is being changed.

GoldenGate Build for Oracle 8i

BUILD REQUEST INSTALLATION MEDIA
BUILD REQUEST ORACLE GOLDENGATE BUILD FOR 8I -32BIT ON WINDOWS (XP, 2003) 1040_WINNT.zip
BUILD REQUEST SUN SOLARIS 5.8 SPARC (64-BIT) , ORACLE 8I GG VERSION 10.0.0.52_00 ggs_solaris8_sparc_ora81_32bit_v10_0_0_52_001.tar
GGS V10.4.0.31.001 BUILD FOR HPUX 11.11 PA-RISC 64BIT / ORACLE 8.1 ggs_hpux1111_pa_ora81_32bit_v10_4_0_31_001.tar

GoldenGate实现Live Standby主备库切换(2)

在《GoldenGate实现Live Standby主备库切换(1)》中我们介绍了如何针对GoldenGate Live standby环境执行计划内的Switchover切换。除去计划内的主备切换,实际生产中更多的故障切换发生在主机故障或主库不可用的情况下,这种情况下一般我们已经无法在Primary上停止应用及extract了;当我们在这样的情况下failover到Standby上后如同在DataGuard环境下一样即便Primary上的数据库恢复了我们也无法直接进行回切了,需要做的是重新配置Primary上的OGG并将Standby上的数据以initial load的形式还原回去,在数据重新同步后才能再切换到Primary上。下面我们就来介绍如何在计划外的情况下从主库failover到备库,并尝试回切:

1.
使用lag replicat命令了解standby上的replicat的延迟情况,若返回"At EOF (end of file)"则说明replicat已应用所有trail中的数据到备库上。
GGSCI (rh3.oracle.com) 1> info all

Program     Status      Group       Lag           Time Since Chkpt

MANAGER     RUNNING                                           
EXTRACT     STOPPED     EXTSTD2     00:00:00      23:42:47    
EXTRACT     STOPPED     PUMPSTD2    00:00:00      23:41:29    
REPLICAT    RUNNING     REPSTD1     00:00:00      00:00:00  

GGSCI (rh3.oracle.com) 5> lag replicat repstd1

Sending GETLAG request to REPLICAT REPSTD1 ...
Last record lag: 5 seconds.
At EOF, no more records to process.

2.
停止standby上的replicat
GGSCI (rh3.oracle.com) 6> stop replicat repstd1

Sending STOP request to REPLICAT REPSTD1 ...
Request processed.

3.
在standby上执行必要的赋予DML权限,启动triggers触发器和cascade delete约束的脚本

4.
启动standby上的extract,
在此之前先确认Standby上的data pump group不被启动,以保证trail文件堆积在standby上
GGSCI (rh3.oracle.com) 15> info all
Program     Status      Group       Lag           Time Since Chkpt
MANAGER     RUNNING                                           
EXTRACT     STOPPED     EXTSTD2     00:00:00      24:04:16    
EXTRACT     STOPPED     PUMPSTD2    00:00:00      24:02:57    
REPLICAT    STOPPED     REPSTD1     00:00:00      00:00:06    

GGSCI (rh3.oracle.com) 16> start extstd2
Sending START request to MANAGER ...
EXTRACT EXTSTD2 starting

5.
此时可以将应用切换到standby上了

==============================================================================
以上步骤完成了故障切换到Standby的过程,接下来我们尝试将应用还原到primary上
1.如果原primary主机已损毁则需要重装Oracle软件,并重建Primary系统上的Goldengate软件目录
2.从primary端启动GGSCI命令
3.删除primary上相关的extract及EXTTRAIL,并重建

GGSCI (rh2.oracle.com) 6> delete extract extstd1
Deleted EXTRACT EXTSTD1.

GGSCI (rh2.oracle.com) 7> delete exttrail /d01/ext/cl

GGSCI (rh2.oracle.com) 14> add extract extstd1,tranlog,begin now
EXTRACT added.

GGSCI (rh2.oracle.com) 15> add exttrail /d01/ext/cl,megabytes 100,extract extstd1
EXTTRAIL added.

4.
在primary上启动Manager
GGSCI (rh2.oracle.com) 18> start Manager
Manager started.

5.
接着在primary上执行disable trigger触发器和cascade delete约束的脚本

6.
在standby上对执行热备份(逻辑,物理的均可);并记录该热备的结束时间

7.
使用standby上的热备份来完成primary上的initial load后,再以HANDLECOLLISIONS选项启动Standby上的replicat
GGSCI (rh2.oracle.com) 22> view params repstd2

-- Identify the Replicat group:
REPLICAT repstd2
-- State that source and target definitions are identical:
ASSUMETARGETDEFS
-- Specify database login information as needed for the database:
userid maclean, password maclean
HANDLECOLLISIONS
-- Specify tables for delivery:
MAP clinic.*, TARGET clinic.*;
-- Exclude specific tables from delivery if needed:
-- MAPEXCLUDE 


GGSCI (rh2.oracle.com) 23> start replicat repstd2

Sending START request to MANAGER ...
REPLICAT REPSTD2 starting

8.并启动standby上的data pump group,将堆积的trail文件传输到Primary上
GGSCI (rh3.oracle.com) 19> start pumpstd2
Sending START request to MANAGER ...
EXTRACT PUMPSTD2 starting

9.使用info replicat观察primary上的replicat,观察其进度是否已晚于完成初始化导出的时间


10.
禁用primary上目前使用的HANDLECOLLISIONS选项
GGSCI (rh2.oracle.com) 26> send replicat repstd2,NOHANDLECOLLISIONS

11.
关闭之前切换到Standby上的一切应用

12.
12.若需要进行数据验证则关闭Standby上的extract、pump及Primary上的replicat:
GGSCI (rh2.oracle.com) 31> lag replicat repstd2
Sending GETLAG request to REPLICAT REPSTD2 ...
Last record lag: 3 seconds.
At EOF, no more records to process.

GGSCI (rh3.oracle.com) 28> stop extstd2
Sending STOP request to EXTRACT EXTSTD2 ...
Request processed.


GGSCI (rh3.oracle.com) 26> stop pumpstd2
Sending STOP request to EXTRACT PUMPSTD2 ...
Request processed.

GGSCI (rh2.oracle.com) 34> stop replicat repstd2
Sending STOP request to REPLICAT REPSTD2 ...
Request processed.

/* 使用Oracle GoldenGate Veridata等工具验证数据一致性,
   若不一致则修复
*/

standby库上:
SQL> select sum(t2) from tv;

   SUM(T2)
----------
5355944997

primary库上:
SQL> select sum(t2) from tv;

   SUM(T2)
----------
5355944997

13.在primary系统上赋予应用相关DML权限,启用触发器及删除约束

14.
修改primary系统上的extract group的begin time为当前,启动Primary到Standby的extract、pump及replicat
GGSCI (rh2.oracle.com) 36> alter extstd1 ,begin now
EXTRACT altered.


GGSCI (rh2.oracle.com) 52> start extract extstd1

Sending START request to MANAGER ...
EXTRACT EXTSTD1 starting


GGSCI (rh2.oracle.com) 53> start extract pumpstd1

Sending START request to MANAGER ...
EXTRACT PUMPSTD1 starting


GGSCI (rh3.oracle.com) 3> start repstd1

Sending START request to MANAGER ...
REPLICAT REPSTD1 starting

此时系统切换回原始的primary->standby状态.
That's great!

数据库基础服务SLA模板

故障级别 界定标准 响应时间 修复时间
紧急故障 出现的故障严重影响到应用的正常运转,且无法绕过该问题。例如:数据库意外crash,导致应用终止。 在接到电话或邮件通知后十分钟内响应,响应形式包括:远程登录协助,电话协助或第一时间赶赴现场支持 8小时
高级故障 出现的故障轻微影响到应用正常运行。
例如:因为不合理的执行计划而导致进程占用大量CPU
在接到电话或邮件通知后二十分钟内响应,响应形式包括:远程登录协助,电话协助或第一时间赶赴现场支持 12小时
中级故障 出现的故障不直接影响应用正常运行,但可能影响数据库的管理和维护。例如:使用exp/imp导入导出工具时出现问题 在接到电话或邮件通知后三十分钟内响应,响应形式包括:远程登录协助,电话协助或第一时间赶赴现场支持 16小时
低级故障 出现的故障不直接影响应用正常运行和数据库的管理维护。但仍需评估其可能的影响,例如:执行维护工作中出现意料外的提示信息 在接到电话或邮件通知后一小时内响应,响应形式包括:远程登录协助,电话协助 20小时

备注1:工程师收到现场服务要求后,将立即在响应时间内开始赶赴现场,
在不出现严重交通拥堵的情况下应在响应时间结束后的一小时之内抵达客户现场。
备注2:以上故障修复后将根据客户需求提供故障报告。

Oracle中国区管理层变更史

据说最早的Oracle中国总公司是在中关村的一个不起眼的四合院里,那是在80年代末,还没有到Oracle在数据库市场上独占鳌头的时间。在那个中国IT的田园时代,光耀万丈的是著名的SYBASE,可惜的是SYBASE的辉煌很快被甲骨文的灿烂所淹没。这里不禁让人想到技术爆炸给小公司带来的巨大影响-虽然关系型数据库的发展从严格意义上来说有别于真正意义上的技术爆炸;当某种领域的技术发展到一定阶段后,就可能出现技术爆炸的阶段,而技术爆炸最直接的得益者往往是小国家抑或者小的公司。并不是说大公司无法把握住技术爆炸的契机,但大多数时间里它们显得太过”笨重”。

历史在不断重演,IT业的变迁更是瞬息万变。就三宅一生来说,人一生经历的软件变迁会要多得多。

今天如日中天的Oracle,亦可能是明天故纸堆中供人研究的甲骨文拓本。

以下文字引用来自IT时代周刊:

编者按:
Oracle(甲骨文)中国公司高层频繁变动,很多人一直疑惑这背后到底是什么原因。
跨国公司在中国的本土化一直是个讨论不完的话题,而水土不服最严重的Oracle中国人事动荡最为典型。由于该公司一直很低调,媒体往往很难进行深入报道,而其原中层员工张建国的看法,令我们打破了对跨国公司惯有的认识。
跨国公司的运作不是人们想象的那么正规,派系斗争、回扣等灰色运作对中国公司的发展影响很直接。但令我们深思的是,随着中国销售额占跨国公司的比重越来越大,这背后是否体现了跨国公司其全球管理文化和中国特色的本地市场之间的深层次矛盾逐渐激化?

不管是华尔街的投资者、硅谷的老手,还是电脑的狂热着迷者,都对Oracle公司的成功和发展感到惊讶。
1979年,拉里·埃里森接受空军的委托,开发出第一版商用关系型数据库,从此踏进了信息管理这个需求无尽的产业,在短短的20多年里一举成为世界级软件巨人。

拉里的国际化之路

1984年,Oracle开始踏进国际门槛。当时一家欧洲的小分销商在欧洲市场推销他们的软件,于是Oracle立刻买断了这家分销商,并收编了所有员工。
随后,Oracle又着手在伦敦通过分销商CACI卖软件,后又买下了CACI,并利用收编的员工和CACI所处的地理位置,在伦敦设立了国际总部,并由原CACI职员领导“Oracle国际”。
Oracle进军国际市场是从利用区域的分销商开始的,而分销商也被委派了很重要的任务。这种做法相当划算,因为分销商能够及时有效地开展地区性业 务,Oracle不必承担扩展分支机构或成立海外子公司的开销。而且,分销商往往也都是军师,因为他们是营销老手,很有经验。Oracle不失时机地利用 他们赚钱。
1995年后,随着公司的持续成长,Oracle希望能够完全把握其分销商,因此开始把他们转变成分公司,以确保他们的忠诚,全力推销产品。
Oracle通过收购并委任当地经销商进行操作的海外扩张,以及以业绩为主要考核指标的模式,使其管理体系和文化基因在海外根本无法复制,也为日后Oracle中国的“混乱”埋下了伏笔。

第一代领袖魏中朝

1989年,Oracle进入中国市场,成为第一家进入中国的软件企业,经过两年的努力,于1991年正式成立了北京独资的子公司——北京Oracle软件系统有限公司,即本文所指的Oracle中国公司。
魏中朝是当时Oracle中国的第一代领航人,任董事总经理职务。我也是在那一年加盟这家公司。十几年后,魏中朝似乎早已被人们所遗忘,在业界及众多媒体眼中,这个名字变得陌生。但他给Oracle中国所带来影响却是不可磨灭的。
在Oracle刚刚打入中国市场的时候,是魏中朝带领着一个由17人组成的团队,在当时这个科技并不怎么发达的国家里打拼天下。魏以独特的经营思路带领 着Oracle中国一步一步向前奋进,开辟了金融、电信、电力、政府、航天等几大领域的市场,有效地提高了Oracle在中国的市场份额,团队也由原来的 17人慢慢扩大到上百人的规模。
所以,在业界,魏中朝被誉为Oracle中国当之无愧的第一代领头羊。1993年,魏中朝由于战略方面与美国总部产生分歧而离开了Oracle中国。

庞伯华宣布撤职冯星君

魏中朝走后,冯星君成为第二位Oracle中国的总经理。
我觉得冯星君是一个非常善于利用资源的人。在他任职时期,冯星君将自己的家族企业——怡信公司发展成为Oracle中国的渠道总代理。之前,冯星君家境 很窘迫,共有兄弟姐妹9个,后来,他的3个弟弟一起创建了怡信公司。当时,作为Oracle中国最大的,也是惟一金牌的代理商,所有渠道商、分销商都要通 过怡信公司拿货,并且销售的每一笔单据都要由怡信公司经手,因而吃回扣也是家常便饭。于是当时有很多人写匿名信向高层投诉,但由于冯星君的职位很高,这些 事情一直没有得到处理。
1995年,Oracle中国办公地点由光大银行搬到了大慧寺12号,那里是国家计生委的一个3层仓库。冯星君要求将这个仓库按照五星级宾馆的档次进行装修,3层楼房再加上花园和食堂,总面积达5千多平方米。冯星君找来的装修公司其实是他弟弟的。
后来在亚太区任职的王义(Mark王)宣告下台,据说就是和冯星君的事有牵连,因为王义与冯星君还有一段“大哥”情缘。冯星君身边的人告诉我,早先冯星 君曾在台湾做狱警,当时王义正在服刑,冯星君有恩于他。1980年代末,冯星君来到大陆,在中关村一带做点小买卖,那时王义已进入Oracle亚太区总部 任职,偶然间遇到了冯星君,王义见小弟如此境遇,于是便提拔冯当上了Oracle中国总经理。
1997年初,庞伯华出任大中国区总裁的职务。 Oracle总部在怀疑冯星君的财务问题和工作能力后,特派庞伯华来调查,冯星君的两个弟弟所在的那家装修公司,另有3个弟弟在Oracle中国区总代理 怡信公司的事情才大白天下。庞伯华本想继续追查下去,却被总部一纸令下,停止调查,直接罢免了冯星君的职务。
于是,在1997年6月25日的一个产品发布会上,庞伯华亲自宣布:撤消冯星君Oracle中国总经理等一切职务,这一发布会通过卫星同时向全球56个国家转播。
撤消冯星君令中国公司员工高兴了好几天。

李文谦只是个摆设

1997年,Oracle正式任命李文谦为Oracle中国总经理,他是庞伯华从台湾调来的。
由于李文谦对内地市场不甚了解,Oracle总部对中国公司基本上失去了控制权。此时,唱主角的应该是张书恒。
1995年,Oracle中国进行了一次大换血,张书恒留了下来。资历老加之对中国市场的了解,张书恒被提升为中国区销售总监兼副总经理,主要负责Oracle中国所有行业的销售及管理工作。
李文谦虽然是Oracle中国的总经理,但因为他对国内市场并不了解,所以只能算个摆设,只有在单子谈下来后签字时,才用一下“李文谦”的名字。而张书 恒名义上是个销售总监,但做的是“老大”的事——操盘整个Oracle中国。Oracle在中国所有行业的销售总经理都是由张书恒亲自挑选并任命的,他们 是杨文胜、李秀国、梦文波、黎彤等,这些人对张书恒言听计从,组成了Oracle中国一派。

矛盾激化双双出局

1999年,李文谦因患脑瘤去美国疗养。次年,胡伯林接替李文谦任Oracle中国总经理。
来到中国后,胡伯林打电话约我到香格里拉饭店了解中国公司的情况,那时我已经离开了Oracle中国。因为当时社会上对Oracle非议很多,胡伯林就想从我这里了解一些外部情况。
胡伯林在多方了解之后,开始进行改革。
胡伯林改革的头一炮就是将张书恒手下各大行业的销售经理提升为“副总”,之后又将这些新提拔的副总一个一个约去谈话。张书恒见此一下就恼了,起身闯进胡 伯林的办公室,拍着桌子跟胡伯林大吵,胡伯林怒斥道:“敢和我这么说话?出去!”于是两人矛盾激化,张书恒先动了手,最后却被军人出身的胡伯林打翻在地。 张书恒叫手下的销售经理们帮他,却没有一个人敢站出来。张书恒火冒三丈,破口大骂,并打了李秀国一个嘴巴,踹了梦文波一脚。
后来,张书恒在与东方龙马(东方龙马是继怡信公司后Oracle中国的又一个总代,也是张书恒扶持起来的)的总经理及员工一起吃饭的时候,提起此事还痛哭流涕,张书恒倍感心寒,一手提拔起来的兄弟,在老大危难之际竟然无人出头,反站在一边袖手旁观。
胡伯林与张书恒矛盾激化后,Oracle总部派南亚区董事总经理陆纯初来调解矛盾。在对张书恒的裁决上产生了严重分歧。陆纯初考虑到张书恒是负责中国所有行业的销售工作,一旦开掉他就会给销售带来不可估量的损失,因此决定不能直接开除。但胡伯林认为:我是Oracle中国的董事总经理,我有权任免中国员 工。由于胡伯林坚持己见,并不把接任大中国区总裁的陆纯初放在眼里,后来导致陆第一个将胡伯林干掉。
张书恒见胡伯林落得如此下场,非常得意。但此时陆纯初也在调查张书恒。张书恒经过这几年的“海捞”,已经成了亿万富翁。陆纯初在掌握了大量情况后,也顾不得对销售的影响了,就准备法办张书恒。张接任一下子傻了,吓得病倒在床3个月没起来。
最后,考虑到公司形象,没有对张书恒进行起诉,只是开除了他了事。张书恒于2004年5月正式离开Oracle中国。

铁腕陆纯初败走麦城

陆纯初来自新加坡,作风强硬的他决心采用更加强悍有效的手段,来规范Oracle中国的管理。他没有过多考虑纷繁复杂的“国情问题”,而是径直采用“猛药下沉疴,快刀斩乱麻”的外科手术办法。无论对于其内部的控制,还是对渠道的整合都是如此。
但在其上任后的两年多时间里,中国公司的成绩单却没有出现让人兴奋的数字。一直被Oracle总部寄予厚望的中国市场,表现得不尽人意。
业绩是考验管理者的最终手段,在时间即为金钱的市场经济时代,Oracle总部也失去了插手中国公司管理的信心。2004年9月,在解决了Oracle中国总经理与副总之间的矛盾5个月之后,陆纯初“因个人原因”选择了离开。
此后,Oracle中国不再保留“大中国区”的设置,改为华北、华东和华南等“三分天下”的三大区域负责人直接向亚太区汇报。
不管是胡伯林还是陆纯初,都可以看作是真正肩负Oracle总部重任,来华改革中国公司的使者。但在错综复杂的人际关系面前,在销售业绩下滑的巨大压力之下,这样的变革最终只能走进死胡同,而执行者最后也成为了牺牲品。

又按:

2004年9月9日,甲骨文公司大中华区总经理陆纯初突然离职。
业界哗然!6月份,甲骨文(中国)副总经理张书恒愤然离职的事情犹如小楼夜雨,残花在地;短短3个月后,执掌大中华区的陆纯初竟然重蹈覆辙,成为甲骨文(中国)又一位“因个人原因”而离职的职业经理人。
甲骨文(中国)接二连三的“内乱”让人们很难以正常的视角来关注它了,具有“铁腕”之称的陆纯初,作为“合格人才”的陆纯初,有着“7年服务和敬业精神”的陆纯初,为什么在自己上任不久,就黯然的离去?
疑问,又一次摆在人们的面前!

突如其来的“逐客令”

9月9日下午,互联网爆出甲骨文公司大中华区总经理兼中国区总经理陆纯初正式离职的消息。随后,网上传出甲骨文中国公司的一份标题为《内部机构调整》的声明。
声明中写道:甲骨文亚太公司已经调整其销售和咨询业务模式,把业务重点放在三个核心领域——应用产品(Applications)、技术产品 (Technology)和行业(Industries),同时配备专业队伍。调整之后,甲骨文公司大中华区区域董事总经理陆纯初将离开公司。并感谢他7 年来为甲骨文公司所作的贡献,并祝愿他在今后的职业生涯中一切顺利。
这份声明,预示着陆纯初将彻底离开甲骨文。《IT时代周刊》记者第一时间拨通了甲骨文(中国)的电话,一位不愿透露姓名的管理人员告诉本刊记者:“陆纯初确实已经离职了,离职以后将不会在甲骨文公司其他分公司任职。”
这也就意味着,这个在甲骨文工作7年的人,将从此离开甲骨文,并脱离任何关系。而甲骨文(中国)在陆纯初离开后,也同时表示将不再保留“大中华区”的设置,目前该公司华北、华南等“三分天下”的三大区域负责人将直接向亚太区汇报。
事实上,有关陆纯初将离开甲骨文(中国)的消息此前数周就已经在业界小范围传播。
9月9日,甲骨文公司高层就此召开了紧急会议,商讨有关陆纯初离职的问题。下午,甲骨文(中国)为此召开网络电话会议,对总部的这一决定作了宣布。
从离职通知本身来看,陆纯初的离去是由于结构调整的需要。而一个甲骨文内部人士竟在接受媒体采访时说:“由于甲骨文在中国的业绩长期难看,陆纯初的走,只是时间早晚而已。”——这明显是事后诸葛亮。
虽然今年以来,甲骨文在中国的市场一直低迷。但并不能说明陆纯初的离去不值得大惊小怪。
这个“逐客令”确实太突然了。对于陆纯初来说,这个“逐客令”确实是“甲骨文”下的,不仅业界很难看懂,他自已也很难读明白。

豪迈誓言的破产

好在3个月时间不长,大家都还记得当时甲骨文(中国)打拼了14年的本土明星经理人、副董事总经理张书恒离职后的十几天,陆纯初6月22日在甲骨文 2005财年媒体交流会上曾十分影射地说过这样一句话:“辞职或者被开除是有分别的。我们筛选人是有资格标准的,有些人不够资格,所以才会被开除掉。”
为此,6月28日,张书恒愤怒地表示,“陆氏的那些言行和说法是不负责任的;陆氏的言行不代表甲骨文公司;陆氏含沙射影的说法,不能掩盖和混淆事实真相。”
当时的陆纯初,肯定是相当豪迈而有信心的。人们也期待着他在甲骨文(中国)能做出不凡的业绩,成为一个新的开端。《IT时代周刊》在6月20号也发表了《甲骨文中国新政》的特别报道,表示了对陆氏新政的关注。
客观地说,虽然陆纯初在2001年12月上任后曾实施过“铁腕政策”,推进其甲骨文中国战略的两个重要步骤:管理规范化、深度本土化。但在其上任后的2年 多时间里,除了2003年12月到2004年5月的业绩稍微有点好转外,甲骨文(中国)的成绩单就没有出现几个让人兴奋的数字。
也许有人会将此现象归结为市场的低迷。但是,同样的ERP市场,为什么SAP连续两年在中国保持了90%左右的增长率。同样的数据库市场,为什么在过去的 一年中,Sybase这个过去的手下败将,竟然能够咸鱼翻身,反戈一击,不但夺取Oracle不少渠道伙伴,而且在开拓新客户方面,工作也颇有成效。
在逐渐失去渠道信任之后,Oracle开始强化对行业市场的直销攻势,不过尽管销售队伍数量比以往有所增加,业绩却一直差强人意。
如今,全球ERP市场开始上扬,而一直被Oracle寄以厚望的在亚太区尤其是中国市场,却总是表现得有点弗如人意。在ERP市场,Oracle受到 SAP等劲敌的蚕食,在赖以成名的数据库市场,则受到微软、IBM、Sybase等老对手的追围拦截,其霸主地位的优势日渐削弱,处境开始变得艰难。
之所以如此,其根本原因在于,陆纯初以及他的团队对于中国的市场、渠道、客户的现实情况了解太少。
他把中国大陆市场重组成华北、华东和华西、华南和香港三大区域。通过这一变革,甲骨文中国各大区分公司和总部的关系得到进一步加强,有利于总部集权管理, 但“三分而治”人为地割裂中国市场;随后,又企图克隆IBM模式,大搞行业市场拓展,而不顾自身实际;另外,将中国的地区性业务交由上海统一管理,而原有 的三大区则将业务重点转向行业市场。变化之快,真是令人眼花缭乱。
如果仅仅是一些流程和经验的问题,还比较容易解决,目前对于Oracle中国来说,一个尴尬而又危险的现实是,它正在逐步失去渠道的忠诚。
按照该公司的理念,Oracle的成功依靠的是该公司强大的产品和品牌影响力。而代理商是一群依靠这种影响力挣钱的群体。
由于在日常合作过程中缺乏沟通,Oracle与多数代理之间缺少足够的信任度。而像“三不管条款”这样的霸王政策也越来越遭到代理的反感。
如果仅仅是一些情绪上的不快,也许还不难化解。只要有了良好的渠道政策,能够让渠道伙伴真正赚到钱,代理们也是可以接受的。但是,Oracle中国的失误在于:在过去几年中,它的渠道政策充斥着短视和对渠道商利益的损害。
从早期的全力依靠代理,到后来旋风般的渠道压缩;从ERP领域的大动干戈,到具体支持手段的空洞匮乏;从合作过程中的转嫁风险,到眼看代理利益受损,却独善其身冷酷旁观。
陆纯初一直致力于Oracle中国的变革,但脱离了现实,可以说是闭门造车。全球ERP市场开始呈现上升的势头,而Oracle在亚太区尤其是中国地区市 场却迟迟不见起色,在ERP市场受到SAP等劲敌的蚕食,而赖以立身的数据库市场在微软、IBM等老对手的夹击下,处境艰难。在这种背景下,Oracle 总部期望通过这次调整,重新树立自己在中国乃至亚太地区ERP和数据库市场领先的地位。
陆纯初的低迷,让Oracle总部也终于失去了耐心。

Oracle中国管理的失败

可以想象,陆纯初离去的心情一定是沉重的,绝对不可能有淡然和洒脱。
但是,真的就只是他的问题吗?
从根本上说,陆的离去也更暴露了Oracle中国管理的失败。
业内专家分析认为,国内软件市场通常的年平均增长速度为20%左右,但是Oracle公司对中国市场定下的发展指标却高达50%到60%。据一位知情者说,前几年Oracle中国公司销售人员能够完成销售任务的大约有七八成,现在则寥寥无几。
从传统上看,Oracle绝对属于业绩为王的企业。一旦销售人员不能完成销售指标,其奖金、待遇将受到很大影响,甚至可能遭到“末位淘汰”的命运。于是, 在每个销售季度末的几天,一些Oracle的销售人员为了完成承诺的任务指标,往往铤而走险,加大对渠道的压货力度,甚至编造假合同骗取代理压货。
在这样巨大的压力下,Oracle在过去两年中,成为业界人员流动频率幅度最大的软件公司之一。
其中,销售部门首当其冲。据《IT时代周刊》记者了解,在过去的一年中,Oracle人员变动幅度超过70%,留下来的也大多抱着骑驴找马的心态。即使是 新来的员工也有不少来去匆匆。一个鲜明的例子是:北京首都机场的一位官员说:“我们的项目是Oracle做的,一个项目没做完,人就换了三批。”
更为严重的是Oracle中国骨干人员的流失。而这些可能会对该公司国内业务的发展造成潜在后遗症。为了填补真空,陆纯初从香港、台湾、新加坡带来大批空降部队,接管中国业务。但是这些职业经理人对于大陆的市场,客户情况毕竟十分陌生。
以往,Oracle中国公司的人员录用和招聘程序非常严格,从而保证了录用人员的质量。但是,现今该公司招人的一个重要标准,是看被录用人员的英文水平,甚至对于行业市场专家的录用也是如此。
还有,甲骨文内部文化的差异,也是其管理的一个难点。
在公司管理方面,陆试图将Oracle亚太区的做法全盘照搬到中国。但是众所周知,中国市场与Oracle亚太区所处的新加坡地区情况差异有天壤之别。简单地将国外的经验与流程引进中国,未必能够发挥这些经验应有的效力。
陆纯初的离去,可以说是Oracle中国管理失败的牺牲品。

险遭杀身之祸

Oracle中国内部到底出现了什么问题呢?
1995年,当时作为Oracle中国董事总经理的冯星君以盗版Oracle数据库为由欲起诉沈志康、于晓东、万国胜、张维平、阚庆利、车迅和贾雷等人,疑点就是这些人去年还骑着自行车上班,第二年却骤然暴富,开起了宝马,住上了别墅。
正在冯星君准备起诉沈志康等人时,冯星君的司机发现有些情况不对劲:每一次冯星君的车一启动,就有一辆车尾随其后跟踪。冯星君开始注意这辆可疑的车,大概观察了一个星期,冯星君觉察出不对劲,就报了警,将这辆车扣了。由于没有造成任何伤害,也没构成犯罪事实,再加上不属于中国内地的管辖区域,于是警方将 此案移交国家公安部门处理,最后将疑犯驱逐出境。
原来,跟踪冯星君的是台湾的黑社会势力,已经在内地潜伏了半个月之久,准备暗杀冯星君,但一直没有找到机会下手。
为什么冯星君会引来杀身之祸?他与台湾黑社会又是什么关系?
冯星君在台湾读书时,因为经济困难,只好选择半工半读,在台湾的一个监狱里做狱警,看管犯人。据说是因为惹恼了黑社会,冯为避难逃亡到了北京,靠做小买卖维持生计。在北京巧遇曾在台湾坐牢的王义后,就投奔了他。从此,乌鸡变凤凰,坐上了Oracle中国总经理的位子。
最终,由于冯星君险遭台湾黑社会追杀,起诉沈志康等人盗版一事才就此打住。
可是,当时发生的这些节外生枝的事情沈志康等人并不知道,还认为冯星君在起诉他们,情急之下心虚的贾雷跳了国际列车身亡,阚庆利从此离开了这个圈子,金盆洗手,其他人也就此离开了Oracle,各自成立了自己的公司。

表彰大会险酿命案

1997年,Oracle中国的业绩取得了突飞猛进的发展,“97工程”让他们顺利地拿下东三省邮电管理局5期工程的大单,也给Informix(英孚美软件公司)、SYBASE(塞贝斯)、CA、Digital(DEC电脑有限公司)等业界几大厂商沉重的打击。
为了表彰作出卓越贡献的员工,1998年,Oracle中国特在北京东三环的长城饭店召开了隆重的群英大会。
1997年初,庞伯华因为调查冯星君并宣布撤消他的职务与后者结了仇,冯为了报复庞伯华,就派人冲击会场,准备向庞伯华下手。在大会即将接近尾声时,我 接到了一个电话,说庞伯华有危险,冯星君正派了一帮打手,让我快点带着人过去。我放下电话就带着几名高手火速赶到长城饭店,那帮人已经将刀子亮了出来,庞 伯华当场吓昏了过去。这时,长城饭店的保安和警察也都赶到了,会场的所有人都被扣留下来配合调查此事。后来,参与打架的人被带到了公安局问话,最后以公司 内部员工间的误会为由终结了此案。
第二天,庞伯华找到我,紧紧握住我的手表示感谢。

换个曲子吹不起来

现在,仍留在Oracle中国做市场的只有黄玮是惟一的元老级人物。
黄玮,女,这位只会吹Oracle一支曲子的“音乐师”,在被开除出Oracle后,还能第二次奏响Oracle“进行曲”。
1989年春的一天,我和黄玮在天安门广场相识,那时她还是个没有稳定工作的“北漂”。1991年,我见黄玮仍然没有找到合适的工作,就将她引荐到了Oracle中国公司。由于没有从事过IT工作,黄玮被安排到市场部做事,负责对外宣传活动。
1996年,Oracle中国董事会将其开除,理由是“行为不检点、索要客户财物和违反公司政策”。公司还发出几百封信件给相关的企业,告诉他们黄玮的为人,表示“这个人不能任用”。
黄玮不服气,欲以“Oracle中国公司歧视员工”为由,向法院提起诉讼,但由于证据不足,黄又转向寻求国家劳动部门的帮助,劳动部门出面调解此事,最后也没有结果。
黄玮丢了工作,就认为是冯星君在搞鬼,于是大量搜集冯的丑闻,发给媒体曝光。那一年,媒体上关于Oracle中国的负面报道不断。
后来,黄玮去了IBM,做电信行业的销售,不到半年就被辞退了。接着又去了UT斯达康,半年后也走人了。之后又到NCR、艾利泰克等公司应聘,结果都一样,做不了长久。
无奈之下,1999年黄玮找到了张书恒,张遂将其引荐给当时执掌Oracle中国大权的李文谦,并向后者解释说黄玮原来在Oracle中国做市场,是由 于与冯星君闹了点误会而离职的。为此,李文谦还特意向我征询了黄玮的事情。李文谦同意再给黄一次机会。这样黄玮又进了Oracle中国,并任职市场部总 监。由此,在业内流传着“黄玮只会吹Oracle一支曲子,换个曲子她吹不起来”的笑柄。
对Oracle中国错综复杂的派系斗争,以及员工的恶行,Oracle总部亦有所闻,但数次直接插手导致的结果往往是业绩下滑,这是拉里·埃里森无论如何都不能接受的。
为了顾及企业形象,Oracle中国的每一次人事动荡都被渲染成锐意改革。那么,在经历了这么多次的改革后,这家公司依然难以稳固。究竟是什么原因呢?是管理,是战略,还是企业文化有问题?
随着中国市场对跨国公司全球业绩贡献越来越高,其全球管理文化和中国特色的本地市场之间的深层次矛盾逐渐激化。这个难题,拉里·埃里森们已经不能逃避!

2004年9月9日,甲骨文公司大中华区总经理陆纯初突然离职。
业界哗然!6月份,甲骨文(中国)副总经理张书恒愤然离职的事情犹如小楼夜雨,残花在地;短短3个月后,执掌大中华区的陆纯初竟然重蹈覆辙,成为甲骨文(中国)又一位“因个人原因”而离职的职业经理人。
甲骨文(中国)接二连三的“内乱”让人们很难以正常的视角来关注它了,具有“铁腕”之称的陆纯初,作为“合格人才”的陆纯初,有着“7年服务和敬业精神”的陆纯初,为什么在自己上任不久,就黯然的离去?
疑问,又一次摆在人们的面前!
突如其来的“逐客令”
9月9日下午,互联网爆出甲骨文公司大中华区总经理兼中国区总经理陆纯初正式离职的消息。随后,网上传出甲骨文中国公司的一份标题为《内部机构调整》的声明。
声明中写道:甲骨文亚太公司已经调整其销售和咨询业务模式,把业务重点放在三个核心领域——应用产品(Applications)、技术产品 (Technology)和行业(Industries),同时配备专业队伍。调整之后,甲骨文公司大中华区区域董事总经理陆纯初将离开公司。并感谢他7 年来为甲骨文公司所作的贡献,并祝愿他在今后的职业生涯中一切顺利。
这份声明,预示着陆纯初将彻底离开甲骨文。《IT时代周刊》记者第一时间拨通了甲骨文(中国)的电话,一位不愿透露姓名的管理人员告诉本刊记者:“陆纯初确实已经离职了,离职以后将不会在甲骨文公司其他分公司任职。”
这也就意味着,这个在甲骨文工作7年的人,将从此离开甲骨文,并脱离任何关系。而甲骨文(中国)在陆纯初离开后,也同时表示将不再保留“大中华区”的设置,目前该公司华北、华南等“三分天下”的三大区域负责人将直接向亚太区汇报。
事实上,有关陆纯初将离开甲骨文(中国)的消息此前数周就已经在业界小范围传播。
9月9日,甲骨文公司高层就此召开了紧急会议,商讨有关陆纯初离职的问题。下午,甲骨文(中国)为此召开网络电话会议,对总部的这一决定作了宣布。
从离职通知本身来看,陆纯初的离去是由于结构调整的需要。而一个甲骨文内部人士竟在接受媒体采访时说:“由于甲骨文在中国的业绩长期难看,陆纯初的走,只是时间早晚而已。”——这明显是事后诸葛亮。
虽然今年以来,甲骨文在中国的市场一直低迷。但并不能说明陆纯初的离去不值得大惊小怪。
这个“逐客令”确实太突然了。对于陆纯初来说,这个“逐客令”确实是“甲骨文”下的,不仅业界很难看懂,他自已也很难读明白。
豪迈誓言的破产
好在3个月时间不长,大家都还记得当时甲骨文(中国)打拼了14年的本土明星经理人、副董事总经理张书恒离职后的十几天,陆纯初6月22日在甲骨文 2005财年媒体交流会上曾十分影射地说过这样一句话:“辞职或者被开除是有分别的。我们筛选人是有资格标准的,有些人不够资格,所以才会被开除掉。”
为此,6月28日,张书恒愤怒地表示,“陆氏的那些言行和说法是不负责任的;陆氏的言行不代表甲骨文公司;陆氏含沙射影的说法,不能掩盖和混淆事实真相。”
当时的陆纯初,肯定是相当豪迈而有信心的。人们也期待着他在甲骨文(中国)能做出不凡的业绩,成为一个新的开端。《IT时代周刊》在6月20号也发表了《甲骨文中国新政》的特别报道,表示了对陆氏新政的关注。
客观地说,虽然陆纯初在2001年12月上任后曾实施过“铁腕政策”,推进其甲骨文中国战略的两个重要步骤:管理规范化、深度本土化。但在其上任后的2年 多时间里,除了2003年12月到2004年5月的业绩稍微有点好转外,甲骨文(中国)的成绩单就没有出现几个让人兴奋的数字。
也许有人会将此现象归结为市场的低迷。但是,同样的ERP市场,为什么SAP连续两年在中国保持了90%左右的增长率。同样的数据库市场,为什么在过去的 一年中,Sybase这个过去的手下败将,竟然能够咸鱼翻身,反戈一击,不但夺取Oracle不少渠道伙伴,而且在开拓新客户方面,工作也颇有成效。
在逐渐失去渠道信任之后,Oracle开始强化对行业市场的直销攻势,不过尽管销售队伍数量比以往有所增加,业绩却一直差强人意。
如今,全球ERP市场开始上扬,而一直被Oracle寄以厚望的在亚太区尤其是中国市场,却总是表现得有点弗如人意。在ERP市场,Oracle受到 SAP等劲敌的蚕食,在赖以成名的数据库市场,则受到微软、IBM、Sybase等老对手的追围拦截,其霸主地位的优势日渐削弱,处境开始变得艰难。
之所以如此,其根本原因在于,陆纯初以及他的团队对于中国的市场、渠道、客户的现实情况了解太少。
他把中国大陆市场重组成华北、华东和华西、华南和香港三大区域。通过这一变革,甲骨文中国各大区分公司和总部的关系得到进一步加强,有利于总部集权管理, 但“三分而治”人为地割裂中国市场;随后,又企图克隆IBM模式,大搞行业市场拓展,而不顾自身实际;另外,将中国的地区性业务交由上海统一管理,而原有 的三大区则将业务重点转向行业市场。变化之快,真是令人眼花缭乱。
如果仅仅是一些流程和经验的问题,还比较容易解决,目前对于Oracle中国来说,一个尴尬而又危险的现实是,它正在逐步失去渠道的忠诚。
按照该公司的理念,Oracle的成功依靠的是该公司强大的产品和品牌影响力。而代理商是一群依靠这种影响力挣钱的群体。
由于在日常合作过程中缺乏沟通,Oracle与多数代理之间缺少足够的信任度。而像“三不管条款”这样的霸王政策也越来越遭到代理的反感。
如果仅仅是一些情绪上的不快,也许还不难化解。只要有了良好的渠道政策,能够让渠道伙伴真正赚到钱,代理们也是可以接受的。但是,Oracle中国的失误在于:在过去几年中,它的渠道政策充斥着短视和对渠道商利益的损害。
从早期的全力依靠代理,到后来旋风般的渠道压缩;从ERP领域的大动干戈,到具体支持手段的空洞匮乏;从合作过程中的转嫁风险,到眼看代理利益受损,却独善其身冷酷旁观。
陆纯初一直致力于Oracle中国的变革,但脱离了现实,可以说是闭门造车。全球ERP市场开始呈现上升的势头,而Oracle在亚太区尤其是中国地区市 场却迟迟不见起色,在ERP市场受到SAP等劲敌的蚕食,而赖以立身的数据库市场在微软、IBM等老对手的夹击下,处境艰难。在这种背景下,Oracle 总部期望通过这次调整,重新树立自己在中国乃至亚太地区ERP和数据库市场领先的地位。
陆纯初的低迷,让Oracle总部也终于失去了耐心。
Oracle中国管理的失败
可以想象,陆纯初离去的心情一定是沉重的,绝对不可能有淡然和洒脱。
但是,真的就只是他的问题吗?
从根本上说,陆的离去也更暴露了Oracle中国管理的失败。
业内专家分析认为,国内软件市场通常的年平均增长速度为20%左右,但是Oracle公司对中国市场定下的发展指标却高达50%到60%。据一位知情者说,前几年Oracle中国公司销售人员能够完成销售任务的大约有七八成,现在则寥寥无几。
从传统上看,Oracle绝对属于业绩为王的企业。一旦销售人员不能完成销售指标,其奖金、待遇将受到很大影响,甚至可能遭到“末位淘汰”的命运。于是, 在每个销售季度末的几天,一些Oracle的销售人员为了完成承诺的任务指标,往往铤而走险,加大对渠道的压货力度,甚至编造假合同骗取代理压货。
在这样巨大的压力下,Oracle在过去两年中,成为业界人员流动频率幅度最大的软件公司之一。
其中,销售部门首当其冲。据《IT时代周刊》记者了解,在过去的一年中,Oracle人员变动幅度超过70%,留下来的也大多抱着骑驴找马的心态。即使是 新来的员工也有不少来去匆匆。一个鲜明的例子是:北京首都机场的一位官员说:“我们的项目是Oracle做的,一个项目没做完,人就换了三批。”
更为严重的是Oracle中国骨干人员的流失。而这些可能会对该公司国内业务的发展造成潜在后遗症。为了填补真空,陆纯初从香港、台湾、新加坡带来大批空降部队,接管中国业务。但是这些职业经理人对于大陆的市场,客户情况毕竟十分陌生。
以往,Oracle中国公司的人员录用和招聘程序非常严格,从而保证了录用人员的质量。但是,现今该公司招人的一个重要标准,是看被录用人员的英文水平,甚至对于行业市场专家的录用也是如此。
还有,甲骨文内部文化的差异,也是其管理的一个难点。
在公司管理方面,陆试图将Oracle亚太区的做法全盘照搬到中国。但是众所周知,中国市场与Oracle亚太区所处的新加坡地区情况差异有天壤之别。简单地将国外的经验与流程引进中国,未必能够发挥这些经验应有的效力。
陆纯初的离去,可以说是Oracle中国管理失败的牺牲品。

How to understand goldengate report file statistics

- Are total process records = inserts + updates + deletes +discards + ignores?
Generally total process records = inserts + updates + deletes +discards + ignores

- Are update collisions is part of updates ?
Yes

- Are delete collisions is part of deletes?
Yes

- Are total successfully process records = inserts + updates + deletes?
Yes

- Can HANDLECOLLISIONS handle ORA-00001 error?
No, HANDLECOLLISIONS can not handle ORA-00001 error. This error is an unique constraint violation error.
HANDLECOLLISIONS control whether or not replicate tries to resolve duplicate-record
and missing-record errors when applying SQL on the target.
These errors can occur during an initial load, when data from source tables is
being loaded to target tables while Oracle Golden Gate is replicating
transactional changes that are being made to those tables.
You can read more about HANDLECOLLISIONS and NOHANDLECOLLISIONS in Oracle® GoldenGate Windows and UNIX Reference Guide.

- How to find the value of bind variable when error is occured by update statement?
In case you want to capture conflict records, you can capture the conflict records to discard file.
Also the conflict record can be written to trace table.

- How to capture the conflict records to discard file?
A discard file is generated when the error condition is encountered by the extract or replicat,
and there is a database error generated from a DDL operation.
Discard file is generally used to do the troubleshooting.

The location of the discard file, is determined by the DISCARDFILE parameter in the Extract or Replicat parameter file.

DISCARDFILE  [, APPEND | PURGE | MEGABYTES ]

Where:

<file name> is the discard file name.
APPEND adds new content to existing content if the file already exists.
PURGE purges the file vefore writing new content.
MEGABYTES <N> sets the maximum size of the file, in megabytes. The default is 1MB.

GoldenGate实现Live Standby主备库切换(1)

Oracle Goldengate目前支持主被动式的双向配置,换而言之OGG可以将来自于激活的主库的数据变化完全复制到从库中,从库在不断同步数据的同时已经为计划内的和计划外的outages做好了故障切换的准备,也就是我们说的Live Standby。这里我们重点介绍一下配置Oracle Goldengate Live Standby系统的步骤,和具体的故障切换过程。

SQL> conn clinic/clinic
Connected.
SQL> drop table tv;
create table tv (t1 int primary key,t2 int,t3 varchar2(30));
Table dropped.

SQL> 

Table created.

SQL> drop sequence seqt1;

create sequence seqt1 start with 1 increment by 1;
Sequence dropped.

SQL> SQL>
Sequence created.

declare
  rnd number(9,2);
begin
   for i in 1..100000 loop
     insert into tv values(seqt1.nextval,i*dbms_random.value,'MACLEAN IS TESTING');
     commit;
   end loop;
end;
/

/* 以上脚本在primary主库的某个应用账户下创建了测试用的数据,
    接着我们可以使用各种工具将数据初始化到从库中,如果在这个过程中
    希望实时在线数据迁移的话,可以参考《Goldengate实现在线数据迁移》
*/

/* 注意我们在Live Standby的环境中往往需要复制sequence序列,以保证切换到备库时业务可以正常进行  */

/* 初始化备库数据后,确保已与主库完全一致 */
primary :
SQL> select sum(t2) from tv;

   SUM(T2)
----------
2498624495

SQL> select last_number from user_sequences;

LAST_NUMBER
-----------
     100001

standby:
SQL> select sum(t2) from tv;

   SUM(T2)
----------
2498624495

SQL> select last_number from user_sequences;

LAST_NUMBER
-----------
     100001

以上完成准备工作后,我们可以进入到正式配置Goldengate live stanby的阶段,包括以下步骤:

  1. 配置由主库到备库的extract、replicat、data pump,该步骤同普通的单向复制没有太大的区别
  2. 配置由备库到主库的extract、replicat、data pump
  3. 启动由主库到备库的extract、replicat、data pump

接下来我们会实践整个配置过程:

1.
创建由主库到备库的extract、data pump、replicat
GGSCI (rh2.oracle.com) 10> dblogin userid maclean
Password: 
Successfully logged into database.

GGSCI (rh2.oracle.com) 11> add trandata clinic.*
Logging of supplemental redo data enabled for table CLINIC.TV


GGSCI (rh2.oracle.com) 4> add extract extstd1,tranlog,begin now
EXTRACT added.

GGSCI (rh2.oracle.com) 5> add exttrail /d01/ext/cl,megabytes 100,extract extstd1
EXTTRAIL added.

GGSCI (rh2.oracle.com) 7> view params extstd1

-- Identify the Extract group:
EXTRACT extstd1
-- Specify database login information as needed for the database:
userid maclean, password maclean
-- Specify the local trail that this Extract writes to:
EXTTRAIL /d01/ext/cl
-- Specify sequences to be captured:
SEQUENCE clinic.seqt1;
-- Specify tables to be captured:
TABLE clinic.*;
-- Exclude specific tables from capture if needed:
-- TABLEEXCLUDE 

GGSCI (rh2.oracle.com) 17> add extract pumpstd1,exttrailsource /d01/ext/cl,begin now
EXTRACT added.

GGSCI (rh2.oracle.com) 98> add rmttrail /d01/rmt/cl,megabytes 100,extract pumpstd1
RMTTRAIL added.

GGSCI (rh2.oracle.com) 129> view params pumpstd1
-- Identify the data pump group:
EXTRACT pumpstd1
userid maclean, password maclean
-- Specify database login information as needed for the database:
userid maclean, password maclean
RMTHOST rh3.oracle.com, MGRPORT 7809
-- Specify the remote trail on the standby system:
RMTTRAIL /d01/rmt/cl
-- Pass data through without mapping, filtering, conversion:
PASSTHRU
sequence clinic.seqt1;
Table clinic.*;


在备库上配置由主库到备库的replicat:

GGSCI (rh3.oracle.com) 4> add replicat repstd1,exttrail /d01/rmt/cl,begin now
REPLICAT added.

GGSCI (rh3.oracle.com) 49> view params repstd1
-- Identify the Replicat group:
REPLICAT repstd1
-- State that source and target definitions are identical:
ASSUMETARGETDEFS
-- Specify database login information as needed for the database:
userid maclean, password maclean
-- Specify tables for delivery:
MAP clinic.*, TARGET clinic.*;
-- Exclude specific tables from delivery if needed:
-- MAPEXCLUDE 

2.
创建由备库到主库的extract、data pump、replicat

GGSCI (rh3.oracle.com) 51> dblogin userid maclean
Password: 
Successfully logged into database.

GGSCI (rh3.oracle.com) 52> add trandata clinic.*
Logging of supplemental redo data enabled for table CLINIC.TV.

/* 不要忘记在备库端的相关表加上追加日志 */

GGSCI (rh3.oracle.com) 53> add extract extstd2,tranlog,begin now
EXTRACT added.

GGSCI (rh3.oracle.com) 54> add exttrail /d01/ext/cl,megabytes 100,extract extstd2
EXTTRAIL added.

GGSCI (rh3.oracle.com) 58> view params extstd2
-- Identify the Extract group:
EXTRACT extstd2
-- Specify database login information as needed for the database:
userid maclean, password maclean
-- Specify the local trail that this Extract writes to:
EXTTRAIL /d01/ext/cl
-- Specify sequences to be captured:
SEQUENCE clinic.seqt1;
-- Specify tables to be captured:
TABLE clinic.*;
-- Exclude specific tables from capture if needed:
-- TABLEEXCLUDE 

GGSCI (rh3.oracle.com) 59> add extract pumpstd2,exttrailsource /d01/ext/cl,begin now
EXTRACT added.

GGSCI (rh3.oracle.com) 60> add rmttrail /d01/rmt/cl,megabytes 100,extract pumpstd2
RMTTRAIL added.

GGSCI (rh3.oracle.com) 63> view params pumpstd2

-- Identify the data pump group:
EXTRACT pumpstd2
userid maclean, password maclean
-- Specify database login information as needed for the database:
userid maclean, password maclean
RMTHOST rh2.oracle.com, MGRPORT 7809
-- Specify the remote trail on the standby system:
RMTTRAIL /d01/rmt/cl
-- Pass data through without mapping, filtering, conversion:
PASSTHRU
sequence clinic.seqt1;
Table clinic.*;

在主库上配置replicat:


GGSCI (rh2.oracle.com) 136> add replicat repstd2,exttrail /d01/rmt/cl,begin now,checkpointtable maclean.ck
REPLICAT added.

GGSCI (rh2.oracle.com) 138> view params repstd2

-- Identify the Replicat group:
REPLICAT repstd2
-- State that source and target definitions are identical:
ASSUMETARGETDEFS
-- Specify database login information as needed for the database:
userid maclean, password maclean
-- Specify tables for delivery:
MAP clinic.*, TARGET clinic.*;
-- Exclude specific tables from delivery if needed:
-- MAPEXCLUDE 

3.
完成以上OGG配置后,可以启动主库到备库的extract、pump、以及replicat:
GGSCI (rh2.oracle.com) 141> start extstd1
Sending START request to MANAGER ...
EXTRACT EXTSTD1 starting


GGSCI (rh2.oracle.com) 142> start pumpstd1
Sending START request to MANAGER ...
EXTRACT PUMPSTD1 starting



GGSCI (rh3.oracle.com) 70> start repstd1
Sending START request to MANAGER ...
REPLICAT REPSTD1 starting

/* 如果你是在offline状态下配置的话,那么此时可以启用应用了*/

接下来我们尝试做有计划的主备库切换演练:

1.
首先停止一切在主库上的应用,这一点和DataGuard Switchover一样。在保证没有活动事务的情况下,才能切换干净。
2.
在主库端使用LAG等命令了解extract的延迟,若返回如"At EOF, no more records to process"的信息,则说明所有事务均已被抽取。
GGSCI (rh2.oracle.com) 144> lag extstd1
Sending GETLAG request to EXTRACT EXTSTD1 ...
Last record lag: 0 seconds.
At EOF, no more records to process.

在EOF的前提下关闭extract:
GGSCI (rh2.oracle.com) 146> stop extstd1 
Sending STOP request to EXTRACT EXTSTD1 ...
Request processed.

3.
同样对pump使用LAG命令,若返回如"At EOF, no more records to process"的信息,则说明已抽取的数据都被发送到备库了。
GGSCI (rh2.oracle.com) 147> lag pumpstd1
Sending GETLAG request to EXTRACT PUMPSTD1 ...
Last record lag: 3 seconds.
At EOF, no more records to process.

在EOF的前提下,关闭data pump
GGSCI (rh2.oracle.com) 148> stop pumpstd1
Sending STOP request to EXTRACT PUMPSTD1 ...
Request processed.

3.
检查备库端replicat的同步情况,如返回"At EOF, no more records to process.",则说明所有记录均被复制。
GGSCI (rh3.oracle.com) 71> lag repstd1
Sending GETLAG request to REPLICAT REPSTD1 ...
Last record lag: 5 seconds.
At EOF, no more records to process.

在EOF的前提下关闭replicat

GGSCI (rh3.oracle.com) 72> stop repstd1
Sending STOP request to REPLICAT REPSTD1 ...
Request processed.

4.
紧接着我们可以在备库上为业务应用用户赋予必要的insert、update、delete权限,启用各种触发器trigger及cascade delete约束等;
以上手段在主库上对应的操作是收回应用业务的权限,disable掉各种触发器及cascade delete约束,
之所以这样做是为了保证在任何时候扮演备库角色的数据库均不应当接受任何除了OGG外的手动的或者应用驱动的业务数据变更,
以保证主备库间的数据一致。

5.
修改原备库上的extract的启动时间到现在,已保证它不去抽取那些之前的重做日志

GGSCI (rh3.oracle.com) 75> alter extstd2 ,begin now
EXTRACT altered.

GGSCI (rh3.oracle.com) 76> start extstd2

Sending START request to MANAGER ...
EXTRACT EXTSTD2 starting


若之前没有启动由备库到主库的pump和replicat的话可以在此时启动:

GGSCI (rh3.oracle.com) 78> start pumpstd2

Sending START request to MANAGER ...
EXTRACT PUMPSTD2 starting

GGSCI (rh2.oracle.com) 161> start repstd2

Sending START request to MANAGER ...
REPLICAT REPSTD2 starting

6.此时我们可以正式启动在原备库现在的主库上的应用了


接下来我们尝试回切到原主库上:
1.前提步骤与之前的切换相似,首先停止在原备库上的任何应用,
之后使用LAG命令确认extract和replicat的进度,在确认后关闭extract和replicat。
完成在主库上的维护工作:包括赋予权限,启用触发器等等。

2.修改原主库上的extract的开始时间为当前,保证它不去处理之前的重做日志:
GGSCI (rh2.oracle.com) 165> alter extract extstd1,begin now
EXTRACT altered.

3.此时我们已经可以启动在原主库现在的主库上的应用了

4.启动最早配置的由主库到备库的extract、pump、replicat:

GGSCI (rh2.oracle.com) 166> start extstd1

Sending START request to MANAGER ...
EXTRACT EXTSTD1 starting

GGSCI (rh2.oracle.com) 171> start pumpstd1

Sending START request to MANAGER ...
EXTRACT PUMPSTD1 starting

GGSCI (rh3.oracle.com) 86> start repstd1

Sending START request to MANAGER ...
REPLICAT REPSTD1 starting


以上完成了OGG的Live Standby中主备库之间的计划内的切换Switchover,That's Great!

Script:partition table into rowid extent chunks

以下脚本可以用于将表按照rowid范围分区,获得指定数目的rowid Extent区间(Group sets of rows in the table into smaller chunks), 以便于非分区表利用rowid来实现并行删除或更新:

 

REM  rowid_ranges should be at least 21
REM  utilize this script help delete large table
REM  if update large table  Why not online redefinition or CTAS
-- This script spits desired number of rowid ranges to be used for any parallel operations.
-- Best to use it for copying a huge table with out of row lob columns in it or CTAS/copy the data over db links.
-- This can also be used to simulate parallel insert/update/delete operations.
-- Maximum number of rowid ranges you can get here is 255.
-- Doesn't work for partitioned tables, but with minor changes it can be adopted easily.

-- Doesn't display any output if the total table blocks are less than rowid ranges times 128.

-- It can split a table into more ranges than the number of extents
From Saibabu Devabhaktuni  http://sai-oracle.blogspot.com/2006/03/how-to-split-table-into-rowid-ranges.html



set verify off
undefine rowid_ranges
undefine segment_name
undefine owner
set head off
set pages 0
set trimspool on

select 'where rowid between ''' ||sys.dbms_rowid.rowid_create(1, d.oid, c.fid1, c.bid1, 0) ||''' and ''' ||sys.dbms_rowid.rowid_create(1, d.oid, c.fid2, c.bid2, 9999) || '''' ||';'
  from (select distinct b.rn,
                        first_value(a.fid) over(partition by b.rn order by a.fid, a.bid rows between unbounded preceding and unbounded following) fid1,
                        last_value(a.fid) over(partition by b.rn order by a.fid, a.bid rows between unbounded preceding and unbounded following) fid2,
                        first_value(decode(sign(range2 - range1),
                                           1,
                                           a.bid +
                                           ((b.rn - a.range1) * a.chunks1),
                                           a.bid)) over(partition by b.rn order by a.fid, a.bid rows between unbounded preceding and unbounded following) bid1,
                        last_value(decode(sign(range2 - range1),
                                          1,
                                          a.bid +
                                          ((b.rn - a.range1 + 1) * a.chunks1) - 1,
                                          (a.bid + a.blocks - 1))) over(partition by b.rn order by a.fid, a.bid rows between unbounded preceding and unbounded following) bid2
          from (select fid,
                       bid,
                       blocks,
                       chunks1,
                       trunc((sum2 - blocks + 1 - 0.1) / chunks1) range1,
                       trunc((sum2 - 0.1) / chunks1) range2
                  from (select /*+ rule */
                         relative_fno fid,
                         block_id bid,
                         blocks,
                         sum(blocks) over() sum1,
                         trunc((sum(blocks) over()) / &&rowid_ranges) chunks1,
                         sum(blocks) over(order by relative_fno, block_id) sum2
                          from dba_extents
                         where segment_name = upper('&&segment_name')
                           and owner = upper('&&owner'))
                 where sum1 > &&rowid_ranges) a,
               (select rownum - 1 rn
                  from dual
                connect by level <= &&rowid_ranges) b
         where b.rn between a.range1 and a.range2) c,
       (select max(data_object_id) oid
          from dba_objects
         where object_name = upper('&&segment_name')
           and owner = upper('&&owner')
           and data_object_id is not null) d
           /

Rolling a Standby Forward using an RMAN Incremental Backup

Rolling a Standby Forward using an RMAN Incremental Backup in 9i

Purpose

This document describes a method of rolling forward a standby database using incremental backups (instead of the typical media recovery process MRP).  The process uses an RMAN incremental backup taken on the primary database which is then applied to the standby database.

Introduction

In normal cases when a gap occurs on a standby database normal gap detection and resolution processes can accurately and efficiently bring the standby up to date.  However, in cases where a physical standby has fallen substantially behind from the primary database it can be beneficial to bring the standby current by using the method described within this article.  The procedure described here can be more efficient for the large gap scenario as incremental backups on the primary and roll forward on the standby can be much faster than normal gap resolution.  In most cases only a small subset of the primary database is altered so incremental backups (and subsequent roll forward) will only contain one complete block for each change versus a large number of change vectors for the same block if read through archivelogs.

This process can be used under either of the following conditions:

  • When the standby database has fallen significantly behind the primary database and there have not been nologging operations performed on the primary database.
  • When nologging operations have been performed on the primary database and the standby database has not yet applied past the point that the nologging operations occurred.

Steps

  1. Stop managed recovery if it is running and mount the standby database.

        SQL> recover managed standby database cancel;
SQL> shutdown immediate;
SQL> startup nomount;
SQL> alter database mount standby database;

  1. Ensure that the primary database is already registered in the recovery catalog.  Note that a recovery catalog must be used since there is no mechanism to manually catalog a backup piece in 9i.

        $ rman target sys/oracle@prod catalog rman/rman@rcvcat
RMAN> register database;

  1. Using RMAN connect to the standby as the target database and catalog the remote standby datafiles as level 0 datafile copies.

        $ rman target sys/oracle@stby catalog rman/rman@rcvcat
RMAN> catalog datafilecopy
'/u03/stby/system01.dbf',
'/u03/stby/undotbs01.dbf',
'/u03/stby/indx01.dbf',
'/u03/stby/tools01.dbf',
'/u03/stby/undotbs02.dbf',
'/u03/stby/users01.dbf'
level 0 tag 'STBY';

  1. Using RMAN connect to the primary database as the target and create the incremental level 1 backup

        $ rman target sys/oracle@prod catalog rman/rman@rcvcat
RMAN> backup incremental level 1 tag 'STBY' database format '/private/%u';

  1. Transfer the incremental backup piece created in the above step to the same path on the standby host.  Connect to the standby as the target database and roll forward the standby datafiles using the incremental backup.

        $ rcp /private/<incr_backup> stby:/private/
$ rman target sys/oracle@stby catalog rman/rman@rcvcat

Note: If datafile names on standby are different, use SET NEWNAME to ensure all standby datafile names are retained:

        RMAN> run {
set newname for datafile 1 to '/u03/stby/system01.dbf';
set newname for datafile 2 to '/u03/stby/undotbs01.dbf';
set newname for datafile 3 to '/u03/stby/indx01.dbf';
set newname for datafile 4 to '/u03/stby/tools01.dbf';
set newname for datafile 5 to '/u03/stby/undotbs02.dbf';
set newname for datafile 6 to '/u03/stby/users01.dbf';
switch datafile all;
recover database noredo;
}

Note:  If datafile names are the same, just run the recover command:

        RMAN> recover database noredo;

  1. Using RMAN delete the incremental backup and uncatalog the datafile copies.

        $ rman target sys/oracle@prod catalog rman/rman@rcvcat
RMAN> delete backup tag 'STBY';
RMAN> change copy tag 'STBY' uncatalog;

  1. If the standby database is on the same host as the primary database then you must uncatalog the online redo logs that are registered in v$archived_log on the standby.  The RECOVER DATABASE command issued in the above step will put entries in v$archived_log if the defined redo logs in the controlfile are accessible.  A local standby will have access to the primary redo logs.  If the standby database is not on the same host as the primary database then this step can be skipped.

        $ rman target sys/oracle@stby catalog rman/rman@rcvcat
RMAN> change archivelog like '...' uncatalog;

  1. On the primary database recreate the standby controlfile.  Transfer the new standby controlfile over to the standby host and mount the standby on the new controlfile.

        SQL> alter database create standby controlfile as '/tmp/stby.ctl';
$ rcp /tmp/stby.ctl stby:/u03/stby

  1. Restart the standby database and start MRP

        SQL> shutdown immediate;
SQL> startup nomount;
SQL> alter database mount standby database;
SQL> alter database recover managed standby database disconnect;

Rolling a Standby Forward using an RMAN Incremental Backup in 10g

Purpose

This document describes a method of rolling forward a standby database using incremental backups (instead of the typical media recovery process MRP).  The process leverages the RMAN incremental roll forward feature available starting with 10g Release 2.

Introduction

In normal cases when a gap occurs on a standby database normal gap detection and resolution processes can accurately and efficiently bring the standby up to date.  However, in cases where a physical standby has fallen substantially behind from the primary database it can be beneficial to bring the standby current by using the method described within this article.  The procedure described here can be more efficient for the large gap scenario as incremental backups on the primary and roll forward on the standby can be much faster than normal gap resolution.  In most cases only a small subset of the primary database is altered so incremental backups (and subsequent roll forward) will only contain one complete block for each change versus a large number of change vectors for the same block if read through archivelogs.

This process can be used under either of the following conditions:

  • When the standby database has fallen significantly behind the primary database and there have not been nologging operations performed on the primary database.
  • When nologging operations have been performed on the primary database and the standby database has not yet applied past the point that the nologging operations occurred.

Steps

1. Stop managed recovery on the physical standby database

        SQL> alter database recover managed standby database cancel;

2. Connect to the recovery catalog and the standby database as the target, and manually catalog the standby datafiles as datafile copies

        RMAN> connect catalog rman/rman@host1/rcvcat
RMAN> connect target sys/manager@host2/stby
RMAN> catalog datafilecopy
'/oracle/oradata/STBY/datafile/o1_mf_system_0chdb5sb_.dbf',
'/oracle/oradata/STBY/datafile/o1_mf_sys_undo_0chdb61n_.dbf',
'/oracle/oradata/STBY/datafile/o1_mf_sysaux_0chdb5wm_.dbf'
level 0 tag 'STBY';

3. Connect to the recovery catalog and the primary database as the target, and create an incremental level 1 backup using the datafile copies as the parent level 0.

        RMAN> connect catalog rman/rman@host1/rcvcat
RMAN> connect target sys/manager@host1/prod
RMAN> backup incremental level 1 tag 'STBY' for recover of copy with tag 'STBY' database format '/private/backup/%u';

4. Copy the newly created backup piece to the same location on the standby system

        $ rcp /private/backup/<incr_backup> stby:/private/backup/

5. Connect to the recovery catalog and the standby database as the target, and roll the datafile copies forward

        RMAN> connect catalog rman/rman@host1/rcvcat
RMAN> connect target sys/manager@host2/stby
RMAN> recover copy of database with tag 'STBY';

6. Delete incremental backup and uncatalog the standby datafiles as datafile copies

        RMAN> delete backup tag 'STBY';
RMAN> change copy like '/oracle/oradata/STBY/datafile/%' uncatalog;

Note: The RECOVER COPY OF DATABASE command causes the ‘STBY’ tag associated with the datafile copies to change to ” (NULL) or back to a previous tag, if one had existed.  Use CHANGE COPY LIKE to uncatalog the standby datafiles as copies.

7. Recreate the Standby Controlfile following
Steps to recreate a Physical Standby Controlfile (Doc ID 459411.1)

8. Restart managed recovery

        SQL> alter database recover managed standby database disconnect;

 

SQL脚本:监控当前重做日志文件使用情况

这个脚本可以用来分析当前重做日志文件(redo logfile)已被用到了什么位置(position)、还剩余多少空间和已使用的百分比:

set linesize 200 pagesize 1400;
select le.leseq "Current log sequence No",
       100 * cp.cpodr_bno / le.lesiz "Percent Full",
       (cpodr_bno - 1) * 512  "bytes used exclude header",
       le.lesiz * 512 - cpodr_bno * 512 "Left space",
       le.lesiz  *512       "logfile size"
  from x$kcccp cp, x$kccle le
 where LE.leseq = CP.cpodr_seq
   and bitand(le.leflg, 24) = 8;

Sample:

SQL> set linesize 200 pagesize 1400;
SQL> select le.leseq "Current log sequence No",
  2         100 * cp.cpodr_bno / le.lesiz "Percent Full",
  3         (cpodr_bno - 1) * 512  "bytes used exclude header",
  4         le.lesiz * 512 - cpodr_bno * 512 "Left space",
  5         le.lesiz  *512       "logfile size"
  6    from x$kcccp cp, x$kccle le
  7   where LE.leseq = CP.cpodr_seq
  8     and bitand(le.leflg, 24) = 8;

Current log sequence No Percent Full bytes used exclude header Left space logfile size
----------------------- ------------ ------------------------- ---------- ------------
                    189   90.7612305                  95169536    9687552    104857600

/*  如上结果显示当前重做日志号为189,使用量百分比是90.7%
    当前日志被使用到了95169536+512 bytes(重做日志文件头)的位置,
    还剩余9687552 bytes的空间,该重做日志的总大小为104857600=100MB
*/

沪ICP备14014813号-2

沪公网安备 31010802001379号