2023年10月

ZK分布式锁实现 https://www.php.cn/faq/466231.html
ZooKeeper是一个为分布式应用提供一致性服务的开源组件,它内部是一个分层的文件系统目录树结构,规定同一个目录下只能有一个唯一文件名。基于ZooKeeper实现分布式锁的步骤如下:
(1)创建一个目录mylock;
(2)线程A想获取锁就在mylock目录下创建临时顺序节点;
(3)获取mylock目录下所有的子节点,然后获取比自己小的兄弟节点,如果不存在,则说明当前线程顺序号最小,获得锁;
(4)线程B获取所有节点,判断自己不是最小节点,设置监听比自己次小的节点;
(5)线程A处理完,删除自己的节点,线程B监听到变更事件,判断自己是不是最小的节点,如果是则获得锁。
Apache的开源库Curator,它是一个ZooKeeper客户端,Curator提供的InterProcessMutex是分布式锁的实现,acquire方法用于获取锁,release方法用于释放锁。
优点:具备高可用、可重入、阻塞锁特性,可解决失效死锁问题。
缺点:因为需要频繁的创建和删除节点,性能上不如Redis方式。主要原因是写操作(获取锁释放锁)都需要在Leader上执行,然后同步到follower。

随着数字化的到来,现在越来越多的软件,开始采用云服务,“云服务”现在已经快成了一个家喻户晓的词了。

使用云计算服务,不同用户需要的服务是不一样的,有些公司可能只需要租借服务器,有些公司可能需要整套服务,而有些个人客户可能希望直接可以通过付费得到一个网站。

所以,根据服务类型的不同,云计算服务可以分为三类,即基础设施即服务(IaaS)、平台即服务(PaaS)和软件即服务(SaaS),后又衍生出aPaaS。

- 阅读剩余部分 -