当前位置: 首页 > news >正文

广东哪有做网赌网站郑州网站技术顾问

广东哪有做网赌网站,郑州网站技术顾问,做网站网络合同,上海企业建站 免费核心思想:当客户端要获取锁,则创建节点,使用完锁,则删除该节点。 客户端获取锁时,在 lock 节点下创建临时顺序节点。然后获取 lock下面的所有子节点,客户端获取到所有的子节点之后,如果发现自己…

核心思想:当客户端要获取锁,则创建节点,使用完锁,则删除该节点。

  1. 客户端获取锁时,在 lock 节点下创建临时顺序节点。
  2. 然后获取 lock下面的所有子节点,客户端获取到所有的子节点之后,如果发现自己创建的子节点序号最小,那么就认为该客户端获取到了锁。使用完锁后,将该节点删除。
  3. 如果发现自己创建的节点并非 lock所有子节点中最小的,说明自己还没有获取到锁。此时客户端需要找到比自己小的那个节点,同时对其注册事件监听器,监听删除事件。
  4. 如果发现比自己小的那个节点被删除,则客户端的 Watcher 会收到相应通知,此时再次判断自己创建的节点:
  5. 是否是 lock 子节点中序号最小的,如果是则获取到了锁;
  6. 如果不是,则重复以上步骤,继续获取到比自己小的一个节点,并注册监听。
    在这里插入图片描述

Curator 实现分布式锁 API

在 Curator 中有五种锁方案
InterProcessSemaphoreMutex:分布式排它锁(非可重入锁)
InterProcessMutex:分布式可重入排它锁
InterProcessReadWriteLock:分布式读写锁
InterProcessMultiLock:将多个锁作为单个实体管理的容器
InterProcessSemaphoreV2:共享信号量

package com.itheima.curator;import org.apache.curator.RetryPolicy;
import org.apache.curator.framework.CuratorFramework;
import org.apache.curator.framework.CuratorFrameworkFactory;
import org.apache.curator.framework.recipes.locks.InterProcessMutex;
import org.apache.curator.retry.ExponentialBackoffRetry;import java.util.concurrent.TimeUnit;//以线程的方式模拟卖票
public class Ticket12306 implements Runnable{private int tickets = 10;//数据库的票数private InterProcessMutex lock ;public Ticket12306(){RetryPolicy retryPolicy = new ExponentialBackoffRetry(3000, 10);CuratorFramework client = CuratorFrameworkFactory.builder().connectString("192.168.2.212:2181").sessionTimeoutMs(60 * 1000).connectionTimeoutMs(15 * 1000).retryPolicy(retryPolicy).build();//开启连接client.start();lock = new InterProcessMutex(client,"/lock");}@Overridepublic void run() {while(true){//获取锁try {lock.acquire(3, TimeUnit.SECONDS);if(tickets > 0){System.out.println(Thread.currentThread()+":"+tickets);Thread.sleep(100);tickets--;}} catch (Exception e) {e.printStackTrace();}finally {//释放锁try {lock.release();} catch (Exception e) {e.printStackTrace();}}}}
}
package com.itheima.curator;public class LockTest {public static void main(String[] args) {Ticket12306 ticket12306 = new Ticket12306();//创建客户端Thread t1 = new Thread(ticket12306,"携程");Thread t2 = new Thread(ticket12306,"飞猪");t1.start();t2.start();}}

代码很简单,可靠性都是zookeeper内部帮你做好的。直接 lock = new InterProcessMutex(client,“/lock”);创建锁对象就行

http://www.ds6.com.cn/news/113071.html

相关文章:

  • wordpress模板左上角的logo换成自己的百度灰色词优化排名
  • 网站模板首页产品市场营销策划书
  • 广东省城乡和建设厅网站seo关键词优化服务
  • ppt做视频的模板下载网站有哪些内容营销策划主要做些什么
  • wordpress图片超链接网站seo外链平台
  • 魔客吧是什麼程序做的网站国内最新消息新闻
  • 辽宁省建设监理协会网站中国十大网站
  • 东莞做网站 信科网络网上推广赚钱项目
  • 网站开发主要学什么百度竞价运营
  • 网站建设需要多长时间在线代理浏览网站
  • 个人 网站建设方案书 备案宁波seo整体优化公司
  • 做网站开发学什么网址浏览大全
  • 怎么看网站用什么代码做的注册公司流程和费用
  • 红色餐饮网站源码怎样才能在百度上面做广告宣传
  • 网站建设策划案全国疫情最新情况公布
  • 网站建设研究方法网络推广服务合同范本
  • 学习做网站建设的学校免费拓客软件
  • 公司网站集群系统架构及建设思路十大计算机培训学校
  • 蓬莱做网站那家好网站建设seo优化培训
  • 十堰最专业的网站建设公司百度正式员工工资待遇
  • 广州网站开发设计营销文案
  • 0797 网站制作长春网站制作计划
  • 青岛建站淘宝指数查询官网
  • 桂林卖手机网站seo平台
  • 公司招聘一个网站建设来做推广seo的优化方向
  • 六安网站建设企业上海牛巨微seo优化
  • 聊城集团网站建设成人速成班有哪些专业
  • vs做网站各种控件的使用新媒体运营怎么自学
  • 外贸优秀网站网络教学平台
  • 控制网站的大量访问怎样优化网站排名