永发信息网

rac redo和undo为什么二个实例不能共享,而需要分开

答案:3  悬赏:20  手机版
解决时间 2021-02-24 09:42
  • 提问者网友:鐵馬踏冰河
  • 2021-02-23 19:45
rac redo和undo为什么二个实例不能共享,而需要分开
最佳答案
  • 五星知识达人网友:过活
  • 2021-02-23 21:17
多实例的数据库中,每个实例拥有一组独立的在线日志记录,也就是我们常说的REDO
THREAD。每个实例独立生成在线日志信息,并且拥有独立的LGWR进程用于写入在线日志文
件。但是在RAC数据库环境中,在线日志文件也必须是所有节点都能够共同访问的。原因也是
一样的,当进行实例恢复的时候,由于相关的数据被写在多个在线日志文件中,因此必须用到所
有的REDO LOG THREAD中的在线日志文件,才能够完成恢复。当我们在数据库上增加一个新
的实例的时候,必须为这个实例创建一组新的在线日志记录,同时激活这个REDO LOG
THREAD。反过来,要从数据库中删除一个实例的时候,我们必须关闭这个THREAD,否则无
论这个实例是否被使用,数据库恢复的时候,仍然会需要使用这个THREAD的日志。在这种情
况下关闭某个THREAD后重新做一次全库备份,会少很多麻烦事。如果你真的碰到了这种情况,
而那个实例的在线日志文件还没删除,那么可以找找数据库恢复所需要的CHANGE#是否在在线
日志中存在,如果存在,你也可以直接恢复这个在线日志来解决这个问题。
在使用UNDO自动管理的模式下,每个实例都需要使用独立的UNDO表空间,这些表空间
的数据文件也必须存放在所有实例都能够访问的共享存储上,其原因我们在前面已经多次提到,
不再重复了。
在多实例数据库环境中,临时表空间是可以多个实例共享的,不过能够共享的仅仅是临时表
空间,临时段是不能共享的。在一个临时表空间上,每个实例必须拥有自己独立的临时段。当临
时表空间满的时候,如果其他实例的临时段有空闲空间,那么这个实例可以从其他实例的临时段
中偷取一个EXTENT,用于扩展自己的临时段。
全部回答
  • 1楼网友:野味小生
  • 2021-02-23 23:00
undo是共享的,redo只有在crash recovery的时候才会被另外一个实例访问。分开但是互相可以访问。主要是为了性能的考虑而分开。
  • 2楼网友:十鸦
  • 2021-02-23 21:30
redo,undo都是按线程分开,现在生产环境所有的数据库undo也是分开的,在网上也看到一些说法,1)分开是为避免资源竟争。2)分开是为保证数据一致性。对于第二点,不太理解 再看看别人怎么说的。
我要举报
如以上回答内容为低俗、色情、不良、暴力、侵权、涉及违法等信息,可以点下面链接进行举报!
点此我要举报以上问答信息
大家都在看
推荐资讯