zookeeper 分布式计数器


zookeeper 分布式计数器

 

应用场景:分布式应用的计数场景

 

**********************************

相关类

 

public class DistributedAtomicInteger implements DistributedAtomicNumber<Integer> {


*****************************
构造方法


    public DistributedAtomicInteger(CuratorFramework client, String counterPath, RetryPolicy retryPolicy) {


    public DistributedAtomicInteger(CuratorFramework client, String counterPath, RetryPolicy retryPolicy, PromotedToLock promotedToLock) {


******************************
常用方法

    public AtomicValue<Integer> get() throws Exception {

    public AtomicValue<Integer> increment() throws Exception {
    public AtomicValue<Integer> add(Integer delta) throws Exception {

    public AtomicValue<Integer> decrement() throws Exception {
    public AtomicValue<Integer> subtract(Integer delta) throws Exception {
 

 

 

**********************************

使用示例

 

******************

config 层

 

@Configuration
public class ZookeeperConfig {

    @Value("${zookeeper.connecting-string}")
    private String connectingString;

    @Bean
    public CuratorFramework initCuratorFramework(){
        CuratorFramework curatorFramework= CuratorFrameworkFactory.builder()
                .connectString(connectingString)
                .sessionTimeoutMs(5000)
                .retryPolicy(new ExponentialBackoffRetry(1000,3,3000))
                .namespace("test")
                .build();
        curatorFramework.start();

        return curatorFramework;
    }
}

 

******************

controller 层

 

@RestController
public class HelloController {

    @Autowired
    private CuratorFramework curatorFramework;

    private String countPath="/count";


    @RequestMapping("/get")
    public Integer get(){
        DistributedAtomicInteger distributedAtomicInteger=new DistributedAtomicInteger(curatorFramework,countPath,new ExponentialBackoffRetry(1000,3,3000));
        ExecutorService executorService=Executors.newFixedThreadPool(5);

        for(int i=0;i<5;i++){
            executorService.submit(()->{
               try{
                   for(int j=0;j<100;j++){
                       distributedAtomicInteger.increment();
                   }
               }catch (Exception e){
                   e.printStackTrace();
               }
            });
        }

        Integer result=null;
        try{
            result=distributedAtomicInteger.get().postValue();
        }catch (Exception e){
            e.printStackTrace();
        }

        return result;
    }
}

 

 

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

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值