免费做网站教程/seo网络优化前景怎么样

免费做网站教程,seo网络优化前景怎么样,衡阳网站推广排名,深圳宝安专业做网站公司MySQL 的锁机制是实现并发控制的核心,不同层级的锁适用于不同场景,以下是对其锁类型的系统分类及详细说明: 一、按锁粒度划分 1. 全局锁(Global Lock) 用途:锁定整个数据库实例,用于全库备份。…

MySQL 的锁机制是实现并发控制的核心,不同层级的锁适用于不同场景,以下是对其锁类型的系统分类及详细说明:

一、按锁粒度划分

1. 全局锁(Global Lock)
  • 用途:锁定整个数据库实例,用于全库备份。

  • 命令:

    FLUSH TABLES WITH READ LOCK;  -- 加全局读锁
    UNLOCK TABLES;                -- 释放锁
    
  • 影响:阻塞所有写操作及DDL操作,仅允许读操作。

2. 表级锁(Table-Level Lock)
  • 表锁(Table Lock)

    • MyISAM引擎使用,分为:

      • 表共享读锁(S锁):允许其他会话读,阻塞写。
      • 表独占写锁(X锁):阻塞其他会话的读写。
    • 命令:

      LOCK TABLES table_name READ;  -- 加读锁
      LOCK TABLES table_name WRITE; -- 加写锁
      UNLOCK TABLES;               -- 释放锁
      
  • 元数据锁(Metadata Lock, MDL)

    • 自动加锁:访问表时自动加MDL读锁,修改结构时加MDL写锁。
    • 问题:长事务可能导致DDL阻塞(如ALTER TABLE等待)。
  • 意向锁(Intention Locks)

    • 作用:快速判断表内是否有行级锁冲突,减少锁检查开销。
    • 类型:
      • 意向共享锁(IS):表明事务意图对某些行加S锁。
      • 意向排他锁(IX):表明事务意图对某些行加X锁。
3. 行级锁(Row-Level Lock)
  • InnoDB引擎支持,锁定索引记录,类型包括:
    • 记录锁(Record Lock):锁定索引中的某一行。
    • 间隙锁(Gap Lock):锁定索引记录之间的间隙,防止幻读。
    • 临键锁(Next-Key Lock):记录锁 + 间隙锁,锁定左开右闭区间。
    • 插入意向锁(Insert Intention Lock):插入前对间隙加锁,允许不同插入位置的并发。
  • 自增锁(AUTO-INC Lock)
    • 用途:确保自增列(AUTO_INCREMENT)值的唯一性。
    • 优化:MySQL 8.0引入轻量级锁(互斥量),减少性能影响。

二、按锁模式划分

1. 共享锁(Shared Lock, S锁)
  • 行为:允许其他事务加S锁,阻塞X锁。

  • 使用场景:

    SELECT ... LOCK IN SHARE MODE;  -- 显式加S锁
    
2. 排他锁(Exclusive Lock, X锁)
  • 行为:阻塞其他事务的S锁和X锁。

  • 使用场景:

    SELECT ... FOR UPDATE;  -- 显式加X锁
    

三、按锁策略划分

1. 悲观锁(Pessimistic Locking)
  • 假设:认为并发冲突频繁,提前加锁。
  • 实现:通过SELECT ... FOR UPDATE显式加锁。
2. 乐观锁(Optimistic Locking)
  • 假设:认为冲突较少,通过版本号或时间戳控制。

  • 实现:

    UPDATE table SET column = new_value, version = version + 1 
    WHERE id = 1 AND version = old_version;
    

四、锁的兼容性与冲突

已存在的锁IS锁(新请求)IX锁(新请求)S锁(新请求)X锁(新请求)
IS锁
IX锁
S锁
X锁

五、不同隔离级别的锁策略

隔离级别锁机制
READ UNCOMMITTED不加锁(通过快照读),可能脏读。
READ COMMITTED行级锁(记录锁),无间隙锁,允许幻读。
REPEATABLE READ临键锁(Next-Key Lock)防止幻读,默认隔离级别。
SERIALIZABLE所有读操作隐式加共享锁,完全串行化。

六、锁的监控与诊断

1. 查看锁信息
SHOW ENGINE INNODB STATUS;          -- 查看Inno引擎状态(含锁信息)
SELECT * FROM information_schema.INNODB_LOCKS;   -- 当前持有的锁
SELECT * FROM information_schema.INNODB_LOCK_WAITS; -- 锁等待关系
2. 常见问题
  • 死锁:事务相互等待锁释放,InnoDB自动检测并回滚代价较小的事务。
  • 锁等待超时:由参数innodb_lock_wait_timeout控制(默认50秒)。

七、示例场景

场景1:防止超卖(临键锁)
-- 事务1:扣减库存
BEGIN;
SELECT stock FROM products WHERE id = 1 FOR UPDATE; -- 加X锁
UPDATE products SET stock = stock - 1 WHERE id = 1;
COMMIT;
  • 作用:临键锁防止其他事务插入新记录,确保库存准确。
场景2:批量插入(间隙锁)
-- 事务1:查询范围数据
BEGIN;
SELECT * FROM orders WHERE amount > 100 FOR UPDATE; -- 对间隙加锁
  • 作用:阻止其他事务在amount > 100范围内插入新数据。

总结

MySQL通过多粒度锁(全局锁、表锁、行锁)和多种锁模式(S/X锁、意向锁)实现高效的并发控制。合理选择事务隔离级别和锁策略(如临键锁防幻读、乐观锁降级冲突)是优化性能的关键。监控工具和诊断命令可帮助快速定位锁争用问题。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/diannao/74407.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

SCI英文论文Accepted后的第一步——Rights and Access

SCI英文论文Accepted后的第一步——Rights and Access 目录 SCI英文论文Accepted后的第一步——Rights and AccessBased on information provided the embargo period/end date is 24 months. 因为选择闭源**Rights and Access(版权与访问权限)**环节是关键第一步,具体操作流…

Qt文件管理系统

引言 今天我将使用model/view模型视图框架来完成一个简单的Qt文件管理系统,主要使用到了QTreeView、QTabelView视图和QFileSystemModel文件系统模型。 界面设计 使用Qt创建项目并勾选创建ui文件,打开ui文件,使用Tree View、Table View、St…

《可爱风格 2048 游戏项目:HTML 实现全解析》

一、引言 在如今的数字化时代,小游戏以其简单易上手、趣味性强的特点深受大家喜爱。2048 游戏作为一款经典的数字合并游戏,拥有庞大的玩家群体。本文将详细介绍一个用单文件 HTML 实现的可爱风格 2048 游戏项目,它不仅具备传统 2048 游戏的基…

C语言 —— 此去经年梦浪荡魂音 - 深入理解指针(卷四)

目录 1. 回调函数 2. qsort函数 2.1 使用qsort函数排序整型数据 2.2 使用qsort排序结构数据 2.3 使用冒泡排序模拟实现qsort函数 1. 回调函数 回调函数其实就是一个通过函数指针调用的函数,如果你把函数的指针作为参数传递给另一个函数,当这个指针被…

Shiro框架漏洞攻略

漏洞原理:服务端在接收到⼀个Cookie时,会按照如下步骤进⾏解析处理:1.检索RememberMe Cookie的值 2.进⾏Base64解码 3.进⾏AES解码 4.进⾏反序列化操作 在第4步中的调⽤反序列化时未进⾏任何过滤,进⽽可以导致出发远程代码执⾏漏…

Ceph集群2025(Squid版)导出高可用NFS集群(下集 )

本次主要对接K8S和传统的一样而已,比较简单,不再过多讲解 官网 https://github.com/kubernetes-csi/csi-driver-nfs/tree/master/chartshelm repo add csi-driver-nfs https://raw.githubusercontent.com/kubernetes-csi/csi-driver-nfs/master/charts helm pull c…

Off-Road-Freespace-Detection配置pytorch2.0.0

一、概述 在github上进行开源代码搜索,发现了Off-Road-Freespace-Detection(链接如下所示)。这是对越野环境可通行区域的检测,在经过测试之后,发现对自己有益。 GitHub - chaytonmin/Off-Road-Freespace-Detection: O…

ChatGPT降低论文AIGC重复率的提示词合集(高效降重方法)

💡 问题:写完毕业论文后,查AIGC率过高,手动降重后仍然很高,该怎么办? 📌 解决方案: 1️⃣ 先查AIGC率(找出AI生成的部分) 2️⃣ 用ChatGPT优化(使…

fastapi+angular评论和回复

说明:fastapiangular评论和回复 效果图: step1:sql show databases; DROP TABLE users; SHOW CREATE TABLE db_school.users; show tables; use db_school; SELECT * FROM db_school.jewelry_categories; CREATE DATABASE db_school; select *from users -- 用户…

AI医疗革命:英伟达GTC 2025医疗健康与生命科学会议全分析

AI医疗革命:英伟达GTC 2025医疗健康与生命科学会议全分析 一、GTC 2025:AI 医疗的算力与生态双突破 1.1 黄仁勋演讲核心:从训练到推理的代际跨越 在科技界瞩目的英伟达 GTC 2025 大会上,英伟达 CEO 黄仁勋的主题演讲成为全场焦点,为 AI 医疗领域带来了极具变革性的消息。…

Apache Spark - 用于大规模数据分析的统一引擎

Apache Spark - 用于大规模数据分析的统一引擎 下载运行示例和 Shell使用 Spark Connect 在 Anywhere 上运行 Spark 客户端应用程序 在集群上启动从这里去哪里使用 Spark Shell 进行交互式分析基本有关数据集作的更多信息缓存 自包含应用程序从这里去哪里 Apache Spark 是用于大…

餐饮管理系统的设计与实现(代码+数据库+LW)

摘 要 互联网发展至今,无论是其理论还是技术都已经成熟,而且它广泛参与在社会中的方方面面。它让信息都可以通过网络传播,搭配信息管理工具可以很好地为人们提供服务。针对信息管理混乱,出错率高,信息安全性差&#…

【C#】Winform调用NModbus实现Modbus TCP 主站通讯

一、前言 Modbus是一种串行通信协议,是工业领域全球最流行的协议之一。 1.1 环境 系统:Win11 工具:Visual Studio 2022 .Net 版本:.Net Framework4.6.0 依赖库:NModbus 3.0.81 1.2 协议类型 Modbus RTU:一…

【leetcode题解】贪心算法

目录 贪心算法 柠檬水找零 将数组和减半的最少操作次数 最大数 摆动序列 最长递增子序列 递增的三元子序列 最长连续递增序列 买卖股票的最佳时机 买卖股票的最佳时机 II K 次取反后最大化的数组和 按身高排序 优势洗牌 最长回文串 增减字符串匹配 分发饼干 最…

Apache Doris

Apache Doris介绍 Apache Doris 是一个基于 MPP 架构的高性能、实时的分析型数据库,以极速易用的特点被人们所熟知,仅需亚秒级响应时间即可返回海量数据下的查询结果,不仅可以支持高并发的点查询场景,也能支持高吞吐的复杂分析场…

VLAN间通信

目录 第一步:配vlan 第二步:配置核心vlanif,MAC地址信息。 第三步:ospf协议 三层交换机(汇聚层): 对于交换机、路由器、防火墙等网络设备而言,接口类型一般存在两种:二层接口,三…

LeetCode热题100精讲——Top2:字母异位词分组【哈希】

你好,我是安然无虞。 文章目录 题目背景字母异位词分组C解法Python解法 题目背景 如果大家对于 哈希 类型的概念并不熟悉, 可以先看我之前为此专门写的算法详解: 蓝桥杯算法竞赛系列第九章巧解哈希题,用这3种数据类型足矣 字母异位词分组 题目链接&am…

基于python+django的图书借阅网站-图书借阅管理系统源码+运行步骤

该系统是基于pythondjango开发的在线图书借阅管理系统。系统适合场景:大学生、课程作业、系统设计、毕业设计。 演示地址 前台地址: http://book.gitapp.cn 后台地址:http://book.gitapp.cn/#/admin 后台管理帐号: 用户名&…

uni-app集成保利威直播、点播SDK经验FQ(二)|小程序直播/APP直播开发适用

通过uniapp集成保利威直播、点播SDK来开发小程序/APP的视频直播能力,在实际开发中可能会遇到的疑问和解决方案,下篇。更多疑问请咨询19924784795。 1.ios不能后台挂起uniapp插件 ios端使用后台音频播放和画中画功能,没有在 manifest.json 进…

【redis】事务详解,相关命令multi、exec、discard 与 watch 的原理

文章目录 什么是事务原子性一致性持久性隔离性 优势与 MySQL 对比用处 事务相关命令开启事务——MULTI执行事务——EXEC放弃当前事务——DISCARD监控某个 key——WATCH作用场景使用方法实现原理 事务总结 什么是事务 MySQL 事务: 原子性:把多个操作&am…