zookeeper分布式锁模拟12306买票

未加锁时容易出现重复买票情况

代码

java 复制代码
public class Ticket12306 implements Runnable{

    // 票数
    private int ticketNums = 10;

    @Override
    public void run() {
        while (true){
            if (ticketNums>0){
                System.out.println(Thread.currentThread() + "抢到了第" + ticketNums + "张票");
                ticketNums--;
            }
        }
    }
}
java 复制代码
public class Main {
    public static void main(String[] args) {
        Ticket12306 ticket = new Ticket12306();

        // 模拟多个线程抢票
        Thread thread1 = new Thread(ticket, "窗口1");
        Thread thread2 = new Thread(ticket, "窗口2");

        thread1.start();
        thread2.start();
    }
}

结果

加分布式锁后

java 复制代码
public class Ticket12306 implements Runnable{

    // 票数
    private int ticketNums = 10;

    public Ticket12306() {
        // 重试策略
        ExponentialBackoffRetry retryPolicy = new ExponentialBackoffRetry(3000, 10);
        CuratorFramework client = CuratorFrameworkFactory.builder()
                .connectString("192.168.106.140:2181")
                .sessionTimeoutMs(60 * 1000)
                .connectionTimeoutMs(15 * 1000)
                .retryPolicy(retryPolicy)
                .build();
        // 开启连接
        client.start();

        lock = new InterProcessMutex(client,"/lock");
    }

    private InterProcessMutex lock;

    @Override
    public void run() {
        while (true){
            try {
                // 获取锁
                lock.acquire(3, TimeUnit.SECONDS);
                if (ticketNums>0){
                    System.out.println(Thread.currentThread() + "抢到了第" + ticketNums + "张票");
                    ticketNums--;
                }
                // 解锁
            } catch (Exception e) {
                throw new RuntimeException(e);
            } finally {
                try {
                    lock.release();
                } catch (Exception e) {
                    throw new RuntimeException(e);
                }
            }

        }
    }
}


出现问题

期间还遇到了一个小插曲,这里顺便记录下。

在连接zookeeper时候出现下面这个错误,刚开始以为是服务端zookeeper出问题了,但是检查后发现没问题,在服务端可正常创建、修改节点信息。

解决方案:关闭服务器防火墙

powershell 复制代码
systemctl stop firewalld
相关推荐
有一个好名字2 小时前
万字 Apache ShardingSphere 完全指南:从分库分表到分布式数据库生态
数据库·分布式·apache
Aurora_eye2 小时前
记录之Ubuntu22.4虚拟机及hadoop为分布式安装
大数据·hadoop·分布式
斯班奇的好朋友阿法法4 小时前
rabbitmq服务端消费端实例(direct和fanout模式)
分布式·rabbitmq·ruby
斯班奇的好朋友阿法法4 小时前
rabbitmq的多交换机(扇出为例)监听实现
分布式·rabbitmq·ruby
没有bug.的程序员4 小时前
分布式架构未来趋势:从云原生到智能边缘的演进之路
java·分布式·微服务·云原生·架构·分布式系统
AI云原生4 小时前
云原生系列Bug修复:Docker镜像无法启动的终极解决方案与排查思路
运维·服务器·python·docker·云原生·容器·bug
武话不港14 小时前
RabbitMQ异常,handleDelivery方法异常
分布式·消息队列·rabbitmq
三坛海会大神5555 小时前
k8s(八)Ingress详解
云原生·容器·kubernetes
荣光波比5 小时前
K8S(十三)—— Helm3从入门到实战:简化Kubernetes应用部署与管理
云原生·容器·kubernetes
^Moon^9 小时前
CycloneDDS:跨主机多进程通信全解析
c++·分布式·dds