1.数据库提供的两种锁的类型
共享锁:当数据对象被加上共享锁时,其他事务能对它进行读操作但不能进行写操作
排它锁:当数据对象被加上排它锁时,其他事务不能进行读和写操作
2.web开发解决并发问题时常用的两种锁
1.乐观锁:在加锁的表中加一个字段代表版本号,通过版本号来控制并发,只有在更新的时候会判断是否加锁 ,这种模式是通过程序来实现的。
优点:不会阻止除程序外的数据库操作,不会出现死锁问题
响应速度快,不需要等待其他并发释放锁
缺点:可能会出现ABA问题。无法解决脏读问题。
乐观锁缺点
1.乐观锁在大量并发的情况下会返回大量的失败,需要重新操作直到成功为止
2.乐观锁存在失效的情况,属小概率事件,需要多个条件共同配合才会出现。如:
- 应用采用自己的策略管理主键ID。如,常见的取当前ID字段的最大值+1作为新ID。
- 版本号字段 ver 默认值为 0 。
- 用户A读取了某个记录准备修改它。该记录正好是ID最大的记录,且之前没被修改过, ver 为默认值 0。
- 在用户A读取完成后,用户B恰好删除了该记录。之后,用户C又插入了一个新记录。
- 此时,阴差阳错的,新插入的记录的ID与用户A读取的记录的ID是一致的, 而版本号两者又都是默认值 0。
- 用户A在用户C操作完成后,修改完成记录并保存。由于ID、ver均可以匹配上, 因此用户A成功保存。但是,却把用户C插入的记录覆盖掉了。
3.会出现ABA问题,解决方法,引入版本号
2.悲观锁: 需要使用数据库的排它锁。当这条数据正在被操作时,其他并发无法进行任何操作。读的时候为后面的更新加 锁,后面的读操作都会等待,在读与更新的时候都会判断是否加锁,这种模式是通过数据库来实现的
缺点: 它的使用意味着性能的损耗,在高并发、锁定持续时间长的情况下,尤其严重。
会出现死锁问题