ITPUB??ì3
新一届的微软MVP评选已经开始,欢迎各位推荐!
ITPUB论坛 » Oracle专题深入讨论 » 数据库容灾、复制解决方案全分析

标题: [精华] 数据库容灾、复制解决方案全分析
离线 lc7888
资深会员



精华贴数 1
个人空间 0
技术积分 2051 (780)
社区积分 114 (3197)
注册日期 2002-4-18
论坛徽章:3
ITPUB元老会员2006贡献徽章授权会员   
      

发表于 2004-7-8 16:16 
数据库容灾、复制解决方案全分析

最近发现论坛上关于数据库远程复制和异地容灾等问题的帖子比较多,现在把我知道的一些解决方案进行一下分析,能力有限,还希望大家多多补充、纠正!

目前,针对oracle数据库的远程复制、容灾主要有以下几种技术或解决方案:
(1)基于存储层的容灾复制方案
这种技术的复制机制是通过基于SAN的存储局域网进行复制,复制针对每个IO进行,复制的数据量比较大;系统可以实现数据的同步或异步两种方式的复制.对大数据量的系统来说有很大的优势(每天日志量在60G以上),但是对主机、操作系统、数据库版本等要求一致,且对络环境的要求比较高。
目标系统不需要有主机,只要有存储设备就可以,如果需要目标系统可读,需要额外的配置和设备,比较麻烦。


只看该作者    顶部
离线 mugen
10g OCM



精华贴数 4
个人空间 0
技术积分 9843 (121)
社区积分 6109 (246)
注册日期 2002-4-5
论坛徽章:13
ITPUB元老ITPUB北京九华山庄2008年会纪念徽章参与2007年甲骨文全球大会(中国上海)纪念ITPUB北京香山2007年会纪念徽章会员2007贡献徽章会员2006贡献徽章
铁扇公主授权会员ITPUB新首页上线纪念徽章生肖徽章:马生肖徽章:蛇生肖徽章:虎

发表于 2004-7-8 17:35 
继续发阿,我很感兴趣的阿


__________________

-----------------
你就是一道风景,没必要在别人风景里面仰视
男人三十不言愁
CEIBS MBA CANDIDATE
ORACLE 11G OCM CANDIDATE
只看该作者    顶部
离线 lc7888
资深会员



精华贴数 1
个人空间 0
技术积分 2051 (780)
社区积分 114 (3197)
注册日期 2002-4-18
论坛徽章:3
ITPUB元老会员2006贡献徽章授权会员   
      

发表于 2004-7-8 17:42 
(2)基于逻辑卷的容灾复制方案

这种技术的机制是通过基于TCP/IP的网络环境进行复制,由操作系统进程捕捉逻辑卷的变化进行复制。其特点与基于存储设备的复制方案比较类似,也可以选择同步或异步两种方式,对主机的软、硬件环境的一致性要求也比较高,对大数据量的应用比较有优势。其目标系统如果要实现可读,需要创建第三方镜像。个人认为这种技术和上面提到的基于存储的复制技术比较适合于超大数据量的系统,或者是应用系统的容灾复制。


只看该作者    顶部
离线 biti_rainy
人生就是如此



精华贴数 37
个人空间 0
技术积分 110928 (4)
社区积分 11774 (124)
注册日期 2001-12-12
论坛徽章:41
现任管理团队成员ITPUB长老会成员ITPUB元老年度论坛发贴之星年度论坛发贴之星ITPUB北京九华山庄2008年会纪念徽章
管理团队2007贡献徽章参与2007年甲骨文全球大会(中国上海)纪念ITPUB北京香山2007年会纪念徽章管理团队2006纪念徽章会员2007贡献徽章会员2006贡献徽章

发表于 2004-7-8 18:09 
我一直有一个困惑,存储级的 复制,假如是同步的,能保证 数据库所有文件一致吗 ?或者说是保证在 异常发生的那一刻有足够的缓冲来保障?

也就是说,复制的时候起文件写入顺序和oracle的顺序一致吗?如果不一致就可能有问题,那么是通过什么机制来实现的呢?


上次一个存储厂商来讲产品,我问技术工程师这个问题,没有能给出答案


__________________
眼界决定边界,态度决定高度
blog:
人生就是如此
只看该作者    顶部
离线 lc7888
资深会员



精华贴数 1
个人空间 0
技术积分 2051 (780)
社区积分 114 (3197)
注册日期 2002-4-18
论坛徽章:3
ITPUB元老会员2006贡献徽章授权会员   
      

发表于 2004-7-8 19:04 


QUOTE:
最初由 biti_rainy 发布
我一直有一个困惑,存储级的 复制,假如是同步的,能保证 数据库所有文件一致吗 ?或者说是保证在 异常发生的那一刻有足够的缓冲来保障?

也就是说,复制的时候起文件写入顺序和oracle的顺序一致吗?如果不一致就可能有问题,那么是通过什么机制来实现的呢?


上次一个存储厂商来讲产品,我问技术工程师这个问题,没有能给出答案


我对存储级的复制没有深入的研究过,主要是我自己的一些理解,你们帮我看一下吧……
我觉得基于存储的复制应该是捕捉原系统存储上的每一个变化,而不是每隔一段时间去复制一下原系统存储上文件内容的改变结果,所以在任意时刻,如果原系统的文件是一致的,那么目标端也应该是一致的,如果原系统没有一致,那目标端也会一样的。形象一点说它的原理可能有点像raid 0,就是说它的写入顺序应该和原系统是一样的。不知道我的理解对不对。另外,在发生故障的那一刻,如果是类似断电的情况,那么肯定会有缓存中数据的损失,也不能100%保证数据文件的一致。一般来说是用这种方式做oracle的容灾备份,在发生灾难以后目标系统的数据库一般是只有2/3的机会是可以正常启动的(这是我接触过的很多这方面的技术人员的一种说法,我没有实际测试过)。我在一个移动运营商那里看到过实际的情况,他们的数据库没有归档,虽然使用了存储级的备份,但是白天却是不做同步的,只有在晚上再将存储同步,到第二天早上,再把存储的同步断掉,然后由另外一台主机来启动目标端存储上的数据库,而且基本上是有1/3的机会目标端数据库是起不来的,需要重新同步。

所以我觉得如果不是数据量大的惊人,其他方式没办法做到同步,或者要同时对数据库和应用进行容灾,存储级的方案是没有什么优势的,尤其是它对网络的环境要求是非常高的,在异地环境中几乎不可能实现。

不知道我的理解对不对,也不知道是不是回答了你的问题,呵呵。欢迎指正!


只看该作者    顶部
离线 biti_rainy
人生就是如此



精华贴数 37
个人空间 0
技术积分 110928 (4)
社区积分 11774 (124)
注册日期 2001-12-12
论坛徽章:41
现任管理团队成员ITPUB长老会成员ITPUB元老年度论坛发贴之星年度论坛发贴之星ITPUB北京九华山庄2008年会纪念徽章
管理团队2007贡献徽章参与2007年甲骨文全球大会(中国上海)纪念ITPUB北京香山2007年会纪念徽章管理团队2006纪念徽章会员2007贡献徽章会员2006贡献徽章

发表于 2004-7-8 20:09 
应该说部分地回答了我的问题,呵呵

因为 实际上存储设备的写入顺序 和  oracle 的进程的写入顺序肯定是不一样的,存储设备一定是做过重整的,那  不管同步或者异步的拷贝都 有可能 存在问题的。

所以我一直对这个方案的可靠性不敢完全相信,这样一来,倒不如 data  guard  可靠了


因为很明显,存储设备拷贝过去的数据文件  不一致是有很大的概率的 ,


__________________
眼界决定边界,态度决定高度
blog:
人生就是如此
只看该作者    顶部
离线 lc7888
资深会员



精华贴数 1
个人空间 0
技术积分 2051 (780)
社区积分 114 (3197)
注册日期 2002-4-18
论坛徽章:3
ITPUB元老会员2006贡献徽章授权会员   
      

发表于 2004-7-9 09:34 


QUOTE:
最初由 biti_rainy 发布
应该说部分地回答了我的问题,呵呵

因为 实际上存储设备的写入顺序 和  oracle 的进程的写入顺序肯定是不一样的,存储设备一定是做过重整的,那  不管同步或者异步的拷贝都 有可能 存在问题的。

所以我一直对这个方案的可靠性不敢完全相信,这样一来,倒不如 data  guard  可靠了


因为很明显,存储设备拷贝过去的数据文件  不一致是有很大的概率的 ,


你的意思是说即使不考虑目标端,仅在源端的情况下,存储设备的写入顺序也是和Oracle不一致的?这应该是一个原因。我觉得还有一种可能性就是在忽略存储设备的这种情况下,在主系统当机,发生切换的时候,主系统存储上的数据文件也不一定能保证一致,就算目标系统保持了完全的同步,也一样不能保正目标端数据可可以启动。


只看该作者    顶部
离线 shangym
山 水 天 雪 桥


精华贴数 1
个人空间 0
技术积分 2325 (681)
社区积分 266 (2038)
注册日期 2002-7-11
论坛徽章:2
会员2006贡献徽章授权会员    
      

发表于 2004-7-9 10:48 
不太理解,为什么说存储设备的写入顺序会和oracle进程的写入顺序不一致阿
如果说仅在源端情况下,存储设备的写入顺序也是和Oracle进程不一致,那么不考虑异地冗灾,那么是不是意味着即使本地服务器crash,也无法启动存储上的数据文件?


__________________
胃口小,话少shangym@itpub.net
只看该作者    顶部
离线 lc7888
资深会员



精华贴数 1
个人空间 0
技术积分 2051 (780)
社区积分 114 (3197)
注册日期 2002-4-18
论坛徽章:3
ITPUB元老会员2006贡献徽章授权会员   
      

发表于 2004-7-9 11:11 


QUOTE:
最初由 shangym 发布
不太理解,为什么说存储设备的写入顺序会和oracle进程的写入顺序不一致阿
如果说仅在源端情况下,存储设备的写入顺序也是和Oracle进程不一致,那么不考虑异地冗灾,那么是不是意味着即使本地服务器crash,也无法启动存储上的数据文件?


我也有这个疑问,以前一直觉得仅考虑主系统的情况下,存储设备的写入顺序应该是和数据库的写入顺序一致的, 但我觉得biti_rainy的理解也是有道理的,存储设备毕竟和一般的磁盘不一样,很可能再写入的时候会作重新的组合,不过不知道具体的证据是什么啊?
按照这种理解,再写入的某一瞬间,数据库的写入顺序和存储的写入顺序可能是不一致的,但既然存储写入的结果跟oracle的写入结果肯定是一致的,那么我们可以把一个比较长的写入过程分成若干个时间段,在每个时间段的结尾,oracle和存储设备的写入结果都是完全一致的,那么这个时间段的大小是多少呢?
呵呵,说得我自己都快晕了,也不知道大家明白我的意思没有……
o
biti_rainy能不能给我们解释一下啊?或者论坛里有没有对存储设备比较了解的兄弟啊?


只看该作者    顶部
离线 biti_rainy
人生就是如此



精华贴数 37
个人空间 0
技术积分 110928 (4)
社区积分 11774 (124)
注册日期 2001-12-12
论坛徽章:41
现任管理团队成员ITPUB长老会成员ITPUB元老年度论坛发贴之星年度论坛发贴之星ITPUB北京九华山庄2008年会纪念徽章
管理团队2007贡献徽章参与2007年甲骨文全球大会(中国上海)纪念ITPUB北京香山2007年会纪念徽章管理团队2006纪念徽章会员2007贡献徽章会员2006贡献徽章

发表于 2004-7-9 11:43 
系统上通常不一致没关系是因为还有 logfile 的存在,而日志文件通常是被写入了磁盘的,oracle本身是顺序写的,还不需要读,应该是被重整的几率比较小

还有存储设备上,比如掉电没关系,是因为存储设备都有足够的短时间供电能力使得 cache 中的数据能被写入磁盘,这个如果不能保证那一掉电基本都要出问题的


但是在复制的那端,我就不清楚是怎么处理的,比如我要停掉复制,开始用起这数据来,或者说设备掉电了,这个时候是怎么处理的


__________________
眼界决定边界,态度决定高度
blog:
人生就是如此
只看该作者    顶部
相关内容


CopyRight 1999-2006 itpub.net All Right Reserved.
北京皓辰广域网络信息技术有限公司. 版权所有
E-mail:Webmaster@itpub.net
京ICP证:010037号 联系我们 法律顾问