DBA_2PC_PENDING 介绍

来源:asp之家 时间:2009-02-28 10:59:00 

DBA_2PC_PENDING
Oracle会自动处理分布事务,保证分布事务的一致性,所有站点全部提交或全部回滚。一般情况下,处理过程在很短的时间内完成,根本无法察觉到。但是,如果在commit或rollback的时候,出现了连接中断或某个数据库站点CRASH的情况,则提交操作可能会无法继续,此时DBA_2PC_PENDING和DBA_2PC_NEIGHBORS中会包含尚未解决的分布事务。

对于绝大多数情况,当恢复连接或CRASH的数据库重新启动后,会自动解决分布式事务,不需要人工干预。只有分布事务锁住的对象急需被访问,锁住的回滚段阻止了其他事务的使用,网络故障或CRASH的数据库的恢复需要很长的时间等情况出现时,才使用人工操作的方式来维护分布式事务。

手工强制提交或回滚将失去二层提交的特性,Oracle无法继续保证事务的一致性,事务的一致性应由手工操作者保证。

对于分布式事务,给事务命名是一个好的习惯。而且在事务执行过程中,可以使用ALTER SESSION ADVISE COMMIT(ROLLBACK);语句,为手工解决分布事务提供参考信息。

当手工解决分布事务出现了冲突,比如一个站点进行了提交而另一个进行了ROLLBACK,这时,DBA_2PC_PENDING中的记录不会清除,必须使用DBMS_TRANSACTION.PURGE_MIXED过程来清除。

如果CRASH的数据库必须重建,或者无法再次启动,则DBA_2PC_PENDING中的记录也无法自动清除,需要使用DBMS_TRANSACTION.PURGE_LOST_DB_ENTRY过程来清除。

Oracle9i中,当使用上述两个过程时,必须处于UNDO_MANAGEMENT=MANUAL的模式,这个限制条件Oracle没有写到文档中。一般使用9i都会使用AUTO模式(Oracle也是这样推荐的),也就是说,想要清除DBA_2PC_PENDING中的信息,必须重起数据库两次,感觉这两个过程的实际用处不大。

出现无法解决的分布式事务时,可能会锁住分布式事务中涉及的表,由于Oracle无法确定哪些数据是提交过的,哪些是没有提交的,无法确定查询操作可见的结果集,因此,即使是查询操作也无法在该表上执行。

使用ALTER SYSTEM DISABLE DISTRIBUTED RECOVERY,可以使Oracle不再自动解决分布事务,即使网络恢复连接或者CRASH的数据库重新启动。ALTER SYSTEM ENABLE DISTRIBUTED RECOVERY恢复自动解决分布事务。

为了保证数据库之间的SCN同步,可以采用两种方法:在查询数据前,执行SELECT * FROM DUAL@REMOTE或者在执行查询前提交或回滚当前事务。

标签:DBA_2PC_PENDING,介绍,事务,Oracle
0
投稿

猜你喜欢

  • asp如何实现强制登录注册?

    2010-05-24 18:13:00
  • windows7下调试ASP+ACCESS错误“未找到提供程序 该程序可能未正确安装”解决办法

    2009-12-26 18:35:00
  • block 和 inline 答案揭晓~ 另付一则,关于 word-break

    2009-12-08 13:06:00
  • 对网页切片算法问题的研究

    2008-06-05 12:41:00
  • MySQL 自动备份与数据库被破坏后的恢复方法

    2010-03-25 10:29:00
  • 兼容FF的图片切换代码

    2009-09-26 20:15:00
  • 数据库性能优化之冗余字段的作用

    2011-03-03 19:21:00
  • 文字的减法

    2007-11-06 12:58:00
  • 有序列表 li ol

    2008-07-30 12:31:00
  • 一位网友的DIV CSS编码笔记——XieBiji

    2008-09-12 12:22:00
  • Oracle9i 动态SGA,PGA特性探索

    2009-04-24 12:39:00
  • 新浪乐居的人不好!哈哈

    2009-07-23 20:39:00
  • 如何使用SQLServer数据库查询累计值

    2009-03-16 14:43:00
  • 微软建议的ASP性能优化28条守则(3)

    2008-02-24 16:30:00
  • 数据库理论:学习基于SQL数据库的算法

    2009-01-13 13:38:00
  • asp如何编写翻页函数?

    2009-11-07 18:46:00
  • Sql2005启用和关闭xp_cmdshell功能

    2008-09-29 15:37:00
  • Oracle SID存在解決方法

    2009-06-19 17:34:00
  • Javascript操作cookie的类

    2007-08-23 09:36:00
  • 简写一个的lightbox显示隐藏层效果(兼容)

    2010-07-23 20:02:00
  • asp之家 网络编程 m.aspxhome.com