etcd 笔记(08)— 基于 etcd 实现分布式锁1. 为什么需要分布式锁?2. 基于数据库实现分布式锁3. 基于 ZooKeeper 实现分布式锁4. 基于缓存实现分布式锁
1. 为什么需要分布式锁?在分布式环境下,数据一致性问题一直是个难点。分布式与单机环境最大的不同在于它不是多线程而是多进程。由于多线程可以共享堆内存,因此可以简单地采取内存作为标记存储位置。而多进程可能都不在同一台物理机上,就需要将标记存储在一个所有进程都能看到的地方。例如秒杀场景就是一个常见的多进程场景。订单服务部署了多个服务实例,如秒杀商品有 4 个,第一个用户购买 3 个,第二个用户购买 2 个,理想状态下第一个用户能购买成功,第二个用户提示购买失败,反之亦可。而实际可能出现的情况是,两个