Rides 入门(五)实现乐观锁

悲观锁:

        很悲观,认为什么时候都会出现问题,无论做什么都会加锁!

乐观锁:

  • 很乐观,认为什么时候都不会出现问题,所以不会上锁!更新数据的时候去判断一下,在此期间是否有人修改过这个数据
  • 获取version
  • 更新的时候比较version

Rides监视测试

 正常执行成功

127.0.0.1:6379> set money 100
OK
127.0.0.1:6379> set out 0
OK
127.0.0.1:6379> watch money    # 监视 money 对象
OK
127.0.0.1:6379> multi    # 事务正常结束,数据期间没有发生变动,这个时候就正常执行成功
OK
127.0.0.1:6379(TX)> DECRBY money 20
QUEUED
127.0.0.1:6379(TX)> INCRBY out 20
QUEUED
127.0.0.1:6379(TX)> exec
1) (integer) 80
2) (integer) 20

测试多线程修改值,使用watch 可以当做redis的乐观所操作

127.0.0.1:6379> watch money    # 监视 money
OK
127.0.0.1:6379> multi
OK
127.0.0.1:6379(TX)> DECRBY money 10
QUEUED
127.0.0.1:6379(TX)> INCRBY out 10
QUEUED
127.0.0.1:6379(TX)> exec    # 执行之前,另外一个县城,修改money的值,这个时候,就会导致事务执行失败
(nil)

上段代码执行exec前新开一个连接修改money值

127.0.0.1:6379>  get money
"80"
127.0.0.1:6379> set money 1000
OK

上边情况,发生失败后,重新获取最新值进行操作

Rides 入门(五)实现乐观锁 

 

上一篇:GO的事务操作


下一篇:前端|HTML5也能操作数据库