当前位置: 首页 > news >正文

说一下mysql的锁

  • 1、全局锁

  • 影响整个数据库的锁。例如,当执行 FLUSH TABLES WITH READ LOCK; 命令时,会阻止其他用户写入数据库,但可以读取。
  • 全局锁简介

  • 全局锁是一种跨所有数据库实例的锁。它可以确保在任何时刻,只有一个事务能够访问共享资源。全局锁通常用于以下场景:

  • 并发性较高的场景。
  • 对数据一致性要求高的场景。
  • 需要防止死锁的情况。
  • 全局锁的实现方式

  • 全局锁的实现方式有很多种,其中最常见的一种是使用分布式锁服务。分布式锁服务是一个独立的进程,它负责管理全局锁。当一个事务需要获取全局锁时,它会向分布式锁服务发送请求。分布式锁服务会检查当前是否有其他事务持有该锁。如果没有,则会将锁授予该事务。如果已经有其他事务持有该锁,则会将该事务放入等待队列。

    当持有锁的事务提交或回滚后,分布式锁服务会将锁释放。此时,等待队列中的第一个事务会获取该锁。

  • 全局锁示例

  • 以下是一个使用全局锁更新数据库中一条数据的示例:

  • import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    import org.springframework.transaction.annotation.Transactional;
    
    @Service
    public class UserService {
    
        @Autowired
        private UserRepository userRepository;
    
        @Autowired
        private DistributedLockService distributedLockService;
    
        @Transactional
        public void updateUser(Long id, String name) {
            // 获取全局锁
            String lockKey = "user:" + id;
            boolean locked = distributedLockService.tryLock(lockKey, 10, TimeUnit.SECONDS);
    
            if (!locked) {
                throw new RuntimeException("Failed to acquire lock");
            }
    
            try {
                // 对数据加锁
                User user = userRepository.findById(id).orElseThrow(() -> new RuntimeException("User not found"));
    
                // 修改数据
                user.setName(name);
    
                // 提交事务
                userRepository.save(user);
            } finally {
                // 释放全局锁
                distributedLockService.unlock(lockKey);
            }
        }
    }
    

    在这个示例中,User 类是一个实体类,它有一个 version 字段,用于存储数据的版本号。updateUser() 方法首先获取全局锁,然后对数据加锁、修改数据和提交事务。最后,它释放全局锁。这样,我们可以防止并发事务同时修改同一行数据,从而确保数据的完整性。

    总结

    全局锁是一种跨所有数据库实例的锁。它可以确保在任何时刻,只有一个事务能够访问共享资源。全局锁通常用于并发性较高的场景、对数据一致性要求高的场景以及需要防止死锁的情况。

  • 2、表级锁

  • 主要分为两种:表共享读锁(Table Read Lock)和表独占写锁(Table Write Lock)。MyISAM 存储引擎主要使用表级锁。InnoDB 存储引擎也支持表级锁,但其更倾向于行级锁。
  • 表级锁简介

  • 表级锁是一种对整张表进行加锁的操作。它可以确保在任何时刻,只有一个事务能够修改表中的数据。表级锁通常用于以下场景:

  • 并发性较高的场景。
  • 对数据一致性要求高的场景。
  • 需要防止死锁的情况。
  • 表级锁的实现方式

  • 表级锁的实现方式有很多种,其中最常见的一种是使用行锁。行锁是一种对表中的一行或多行数据进行加锁的操作。当一个事务需要修改表中的数据时,它会对要修改的行加锁。这样,其他事务就无法修改这些行的数据。

    表级锁也可以通过对整个表加锁来实现。当一个事务需要修改表中的数据时,它会对整个表加锁。这样,其他事务就无法修改表中的任何数据。

    表级锁示例

  • 以下是一个使用表级锁更新数据库中一张表所有数据的示例:

  • import org.springframework.beans.factory.annotation.Autowired;
    import org.springframework.stereotype.Service;
    import org.springframework.transaction.annotation.Transactional;
    
    @Service
    public class UserService {
    
        @Autowired
        private UserRepository userRepository;
    
        @Transactional
        public void updateAllUsers(String name) {
            // 获取表级锁
            userRepos

相关文章:

  • Configure Virtual Serial Port Driver串口模拟器VSPD
  • 【手把手带你玩转MyBatis】基础篇:掌握事务管理,确保数据操作的原子性与一致性
  • 【JVM调优系列】如何导出堆内存文件
  • 微信小程序支付之V2支付
  • QT上位机开发(进度条操作)
  • 2024.1.14
  • 【驱动】TI AM437x(内核调试-06):网卡(PHY和MAC)、七层OSI
  • C++笔记
  • springcloud gateway动态路由
  • Erlang/OTP中的日志与事件处理(一)
  • vue2使用electron以及打包配置
  • 【小白专用】C# 连接 MySQL 数据库
  • K8S 日志方案
  • webpack的性能优化(二)——减少打包体积
  • Baumer工业相机堡盟工业相机如何使用OpenCV实现相机图像的显示(C#)
  • Pandas实战100例 | 案例 13: 数据分类 - 使用 `cut` 对数值进行分箱
  • 软件测试|SQLAlchemy环境安装与基础使用
  • Ftrans飞驰云联荣获“CSA 2023安全创新奖”
  • Spark详解
  • 环境变量详细说明
  • 哪种“网红减肥法”比较靠谱?医学专家和运动专家共同解答
  • 云南大理铁路枢纽工程建设取得两大进展,预计明年建成
  • 盖茨说对中国技术封锁起到反作用
  • 老人将房产遗赠给外孙,三个女儿却认为遗嘱应无效,法院判了
  • 秦洪看盘|预期改善,或迎来新的增量资金
  • 有关部门负责人就《新时代的中国国家安全》白皮书答记者问