摘要: 摘要:本文要实现的是一种使用redis来实现分布式锁。 1、分布式锁 分布式锁在是一种用来安全访问分式式机器上变量的安全方案,一般用在全局id生成,秒杀系统,全局变量共享、分布式事务等。一般会有两种实现方案,一种是悲观锁的实现,一种是乐观锁的实现。悲观锁的并发性能差,但是能保证不会发生脏数据的可能性 阅读全文
posted @ 2018-02-06 11:34 程序猿001 阅读(3790) 评论(0) 推荐(0) 编辑
摘要: 本文使用redis来实现乐观锁,并以秒杀系统为实例来讲解整个过程。 乐观锁 大多数是基于数据版本(version)的记录机制实现的。即为数据增加一个版本标识,在基于数据库表的版本解决方案中,一般是通过为数据库表增加一个”version”字段来实现读取出数据时,将此版本号一同读出,之后更新时,对此版本 阅读全文
posted @ 2018-02-06 11:30 程序猿001 阅读(1231) 评论(0) 推荐(0) 编辑
摘要: MySQL中select * for update锁表的问题 由于InnoDB预设是Row-Level Lock,所以只有「明确」的指定主键,MySQL才会执行Row lock (只锁住被选取的资料例) ,否则MySQL将会执行Table Lock (将整个资料表单给锁住)。 举个例子: 假设有个表 阅读全文
posted @ 2018-02-06 10:17 程序猿001 阅读(294) 评论(0) 推荐(0) 编辑