首先创建表
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