基于数据库的分布式锁

首先创建表

CREATE TABLE
    ap_task_lock
    (
        id INT(30) NOT NULL COMMENT '锁编号',
        descs VARCHAR(250) COMMENT '描述',
        state VARCHAR(1) COMMENT '状态 0-未持有 1-持有',
        ip VARCHAR(30) COMMENT 'IP',
        TIME TIMESTAMP NULL COMMENT '时间',
        PRIMARY KEY (id)
    )
    ENGINE=InnoDB DEFAULT CHARSET=utf8mb4 COMMENT='任务锁';

思路:每个锁编号对应唯一的一个任务,每次进行任务前,需要查询这个表对应的锁编号对应的状态,只有状态为0才能将代码进行下去否则return。当有进程获取到这个锁之后,将id对应的state修改为1表示已有进程在进行这个任务,其他进程将不能进行这个任务。同时为了避免死锁,会设置一个强制拿锁的机制,即在数据库将state改为1后,5分钟后如果发现该锁还是锁定状态的话,那就强制改为0

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值