java dubbo 分布式锁_浅谈Java(SpringBoot)基于zookeeper的分布式锁实现

通过zookeeper实现分布式锁

1、创建zookeeper的client

首先通过CuratorFrameworkFactory创建一个连接zookeeper的连接CuratorFramework client

public class CuratorFactoryBean implements FactoryBean, InitializingBean, DisposableBean {

private static final Logger LOGGER = LoggerFactory.getLogger(ContractFileInfoController.class);

private String connectionString;

private int sessionTimeoutMs;

private int connectionTimeoutMs;

private RetryPolicy retryPolicy;

private CuratorFramework client;

public CuratorFactoryBean(String connectionString) {

this(connectionString, 500, 500);

}

public CuratorFactoryBean(String connectionString, int sessionTimeoutMs, int connectionTimeoutMs) {

this.connectionString = connectionString;

this.sessionTimeoutMs = sessionTimeoutMs;

this.connectionTimeoutMs = connectionTimeoutMs;

}

@Override

public void destroy() throws Exception {

LOGGER.info("Closing curator framework...");

this.client.close();

LOGGER.info("Closed curator framework.");

}

@Override

public CuratorFramework getObject() throws Exception {

return this.client;

}

@Override

public Class> getObjectType() {

return this.client != null ? this.client.getClass() : CuratorFramework.class;

}

@Override

public boolean isSingleton() {

return true;

}

@Override

public void afterPropertiesSet() throws Exception {

if (StringUtils.isEmpty(this.connectionString)) {

throw new IllegalStateException("connectionString can not be empty.");

} else {

if (this.retryPolicy == null) {

this.retryPolicy = new ExponentialBackoffRetry(1000, 2147483647, 180000);

}

this.client = CuratorFrameworkFactory.newClient(this.connectionString, this.sessionTimeoutMs, this.connectionTimeoutMs, this.retryPolicy);

this.client.start();

this.client.blockUntilConnected(30, TimeUnit.MILLISECONDS);

}

}

public void setConnectionString(String connectionString) {

this.connectionString = connectionString;

}

public void setSessionTimeoutMs(int sessionTimeoutMs) {

this.sessionTimeoutMs = sessionTimeoutMs;

}

public void setConnectionTimeoutMs(int connectionTimeoutMs) {

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值