infinity mysql_MySql锁机制

本文围绕MySQL锁与事务展开。介绍了MySQL默认事务隔离级别为可重复读(RR),详细阐述了共享锁、排它锁、自增锁、记录锁、间隙锁和临键锁的特点、使用场景及产生条件,如间隙锁可防止幻读,且只有在RR隔离级别下产生。

一、锁跟事务有关

mysql默认的事务隔离级别是:可重复读(RR)

二、共享锁(读锁/S锁)

1. 多个事务的查询语句,对同一数据,可以共享一把锁,都能访问到最新数据

2. 如果只有一个事务获取到了一个共享锁,可以更新、删除

3. 如果多个事务都获取到了同一个共享锁,多个事务都不可以更新、删除

4. 使用场景:多个事务都可以获取最新数据

三、排它锁(写锁/X锁)

1. 不能与其他锁共存,只有一个事务能拿到锁

2. 锁释放后,其他事务才能获取

3. 使用场景:一个事务进行查询、更新、删除操作

四、自增锁

1. 如果表中存在自增字段,MySql会自动维护一个自增锁

2. 当事务插入一条数据,自增+1,事务未提交时,查不到这条数据,提交后才能查到

五、记录锁(行锁)

1. 锁住一行记录

2. 阻止该行被其他事务操作(删除、更新、插入同样的ID)

六、间隙锁(gap lock)

1. 概念

a. 索引记录中有间隔,例如id字段上建了索引,表里有3条记录,id分别为1,3,5

b. 两条记录之间的间隔(1,3], (3,5]

c. 第一条索引之前的范围,即(-infinity,1]

d. 最后一条索引之后的范围,即(5,infinity]

e. 这种间隔或者范围之间的锁,叫做间隙锁,间隙是前开后闭原则

f. 间隙锁的作用:间隙内的数据,即一定范围内的数据,在锁定情况下,不发生变化

2. 产生间隙锁的条件

a. 使用普通索引锁定

b. 使用多列唯一索引

c. 使用唯一索引锁定多行记录

3. 只有在事务隔离级别为RR时,才会产生

4. 唯一索引:锁住多条记录,或者不存在的记录时,才会产生间隙锁

5. 普通索引:锁住单条、多条记录,都会产生间隙锁

6. 锁住该条记录相邻的两个键之间的空白区域,防止其他事务在这个范围内插入、修改、删除

7. 防止出现幻读,幻读是因为新增或更新操作,范围查询会出现数据不一致的问题

8. 如果事务隔离级别是RC,间隙锁将会失效

七、临键锁(next-key lock)

1. 记录锁和间隙锁的组合,既包含索引记录,又包含索引区间

2. 记录锁、间隙锁、临键锁都是排它锁

参考:

### 配置DRBD与MySQL实现高可用性 #### 1. 安装必要的软件包 为了使DRBD能够与MySQL协同工作,需要安装一些特定的组件。对于操作系统层面的操作如下所示: ```bash yum install -y drbd84 kmod-drbd84 pacemaker corosync pcs resource-agents heartbeat ``` 此命令用于CentOS/RHEL环境,在Debian/Ubuntu环境下则应使用`apt-get`来代替。 #### 2. 设置DRBD资源定义文件 创建并编辑 `/etc/drbd.d/mysql.res` 文件以定义DRBD资源配置[^1]。 ```plaintext resource r0 { protocol C; startup { wfc-timeout 15; degr-wfc-timeout 60; } disk { on-io-error detach; } net { cram-hmac-alg sha1; shared-secret "mysecret"; } syncer { rate 10M; } on master-node { device /dev/drbd0; disk /dev/sdb1; address 192.168.1.1:7789; meta-disk internal; } on slave-node { device /dev/drbd0; disk /dev/sdb1; address 192.168.1.2:7789; meta-disk internal; } } ``` 上述配置指定了两台节点间通信所需的信息以及磁盘分区详情。 #### 3. 初始化DRBD设备 初始化之前准备好的物理卷作为DRBD使用的存储介质,并格式化新创建的逻辑卷以便后续挂载到指定路径下供MySQL服务访问。 ```bash drbdadm create-md r0 mkfs.ext4 /dev/drbd0 mkdir -p /var/lib/mysql_drbd mount /dev/drbd0 /var/lib/mysql_drbd/ ``` #### 4. 启动DRBD服务并与Pacemaker集成 启动DRBD服务并将它加入到Pacemaker管理之下,确保即使发生故障切换也能自动恢复数据库功能。 ```bash systemctl start drbd pcs property set stonith-enabled=false pcs resource create MS_mysqldrbd ocf:linbit:drbd \ drbd_resource=r0 op monitor interval=29s role=Master \ op monitor interval=31s role=Slave --group mysql-group pcs constraint colocation add promote MS_mysqldrbd with MySQLD INFINITY pcs constraint order mysqlip then promote MS_mysqldrbd then drbdfs then MySQLD ``` 这里设置了DRBD资源监控频率及时序约束条件,保证了数据一致性的同时也提高了系统的稳定性。 #### 5. 移植现有MySQL实例至新的位置 如果已有正在运行中的MySQL实例,则需将其全部数据迁移到由DRBD提供的共享存储空间内;如果是全新部署的话可以直接跳过这一步骤[^2]。 ```bash service mysqld stop rsync -avz /var/lib/mysql/* /var/lib/mysql_drbd/ chown -i 's|^datadir.*$|datadir=/var/lib/mysql_drbd|' /etc/my.cnf ``` 以上操作完成了原有目录下的所有文件向目标位置迁移的过程,并修改了默认的数据存放路径设置。 #### 6. 创建并验证主从关系 最后要确认集群内部各成员之间的角色分配情况是否正确无误,可通过查询slave状态来进行初步判断[^3]。 ```sql SHOW SLAVE STATUS \G ; ``` 当看到 `Slave_IO_Running: Yes` 和 `Slave_SQL_Running: Yes` 的时候即表示已经成功建立了有效的复制连接。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值