可串行化准则:
多个事务的并发执行时正确的,当且仅当其结果按某一次序串行执行它们时的结果相同,这种调度策略称为可串行化调度。
可串行化是并发事务正确性的准则,一个给定的并发调度,当且仅当它是可串行化的,才认为是正确的。
封锁是实现并发控制的非常重要的技术。
封锁是指事务在对数据对象进行操作以前,先请求系统对其加锁,成功加锁之后该事务就对该数据对象有了控制权,只有该事务对其进行解锁之后,其他的事务才能更新它.
A: 排它锁(也称作X锁): 可读可写
如果事务T在对某个数据对象实施了X锁,那么其他的事务必须要等到T事务结束对该数据对象的X锁之后,才能对这个数据进行加锁。
B: 共享锁(也称作S锁):只能进行读取工作
如果事务T在对某个数据对象实施了S锁,那么其他的事务也能对该数据对象实施S锁,但是对这个数据对象施加的所有S锁都释放之前不允许任何事务对该数据对象实施X锁。
问题描述: 封锁技术可以避免一些并发操作引起的不一致错误,但也会产生其他的一些问题,活锁和死锁。
活锁: 如果某个事务处在永远等待的状态,得不到封锁的机会,这种现象为活锁,避免这种锁最好的方法就是采用先来先服务的策略。
死锁: 两个或两个以上的事务都处于等待状态每个事务都在等待对方事务接触封锁,它才能继续执行下去,这样任何事务都处于等待状态而无法继续执行的现象称为死锁
解决方案: //大致有以下几类
A、 死锁的预防
B、 死锁的诊断与预防 //: 尽量别写这样的代码, 如果出现问题了, 只能手动修改源代码.
网友评论