事务冲突:
什么是事务冲突?比如有三个人拥有同一张银行卡,一个共有3000元,一个准备消费2000,一个准备消费1000,一个准备消费500,当同时进行操作时,会是你的银行卡余额达到-500,在实际生活中这是不能得,但是在计算机的数据库中存在这样的漏洞,我们给出的方案都是为数据上锁,主要有以下两种锁机制。
悲观锁:
每次操作,都认为别人会修改(悲观的思想),所以每次操作都会上锁,防止别人对数据操作,操作完后解锁
传统关系型数据库里运用了悲观锁机制:行锁,表锁
乐观锁:
每次操作,认为别人不会修改,不上锁(乐观的思想),但是更新时会判断有无人修改数据,在数据上加上版本号,之后人操作需要校对版本号,之后才能操作
Redis的乐观锁案例:
1.同时开启两个Shell绑定Linux,任意一个设定一个kv值
2.在两边使用watch命令该key
3.分别在shell中操作该key的值
4.操作结果
发现后操作的命令执行失败,原因是:在第一次操作时Redis给数据上了乐观锁,也就使得版本号改变,第二个修改的操作与数据版本号不一致,造成无法操作。