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

桐乡市住房建设局网站公示网站pv uv统计

桐乡市住房建设局网站公示,网站pv uv统计,wordpress添加缩略图,建设h5网站MySQL 的锁机制是数据库并发控制的核心,作为 Java 架构师需要深入理解其实现原理和适用场景。以下是 MySQL 锁机制的详细解析: 一、锁的分类维度 1. 按锁粒度划分 锁粒度特点适用场景​全局锁​锁定整个数据库(FLUSH TABLES WITH READ LOC…

MySQL 的锁机制是数据库并发控制的核心,作为 Java 架构师需要深入理解其实现原理和适用场景。以下是 MySQL 锁机制的详细解析:

一、锁的分类维度

1. 按锁粒度划分
锁粒度特点适用场景
全局锁锁定整个数据库(FLUSH TABLES WITH READ LOCK全库逻辑备份
表级锁锁定整张表(LOCK TABLESMyISAM 存储引擎默认
行级锁锁定单行或多行记录(InnoDB 特有)高并发 OLTP 场景
元数据锁自动管理表结构变更的锁(Metadata Lock, MDL)DDL 操作保护
2. 按锁模式划分
锁模式兼容性特点
S 锁与 S 锁兼容,与 X 锁互斥SELECT ... LOCK IN SHARE MODE
X 锁与所有锁互斥SELECT ... FOR UPDATE / UPDATE/DELETE
IS 锁意向共享锁(表级锁)表示事务准备在表内某些行加 S 锁
IX 锁意向排他锁(表级锁)表示事务准备在表内某些行加 X 锁

二、InnoDB 行锁实现机制

1. 记录锁(Record Lock)
  • 物理实现​:锁定索引记录(即使表没有索引,也会隐式创建聚簇索引)
  • 加锁方式​:UPDATE table SET col=val WHERE id=1(锁定 id=1 的索引项)
2. 间隙锁(Gap Lock)
  • 作用范围​:锁定索引记录之间的区间(开区间)
  • 典型场景​:SELECT * FROM t WHERE id BETWEEN 5 AND 7 FOR UPDATE
  • 解决的问题​:防止幻读(Phantom Read)
3. 临键锁(Next-Key Lock)
  • 组成​:记录锁 + 间隙锁(左开右闭区间)
  • 示例​:索引包含值 10, 20, 30 → 锁定区间 (-∞,10], (10,20], (20,30], (30,+∞)
4. 插入意向锁(Insert Intention Lock)
  • 特点​:插入操作前加的间隙锁,不同事务的插入意向锁不互斥
  • 作用​:提高并发插入性能

三、锁的兼容矩阵

XIXSIS
X冲突冲突冲突冲突
IX冲突兼容冲突兼容
S冲突冲突兼容兼容
IS冲突兼容兼容兼容

四、锁与事务隔离级别

隔离级别锁行为特点
READ UNCOMMITTED不加锁读取(可能脏读)
READ COMMITTED (RC)​语句级快照,不使用间隙锁(可能幻读)
REPEATABLE READ (RR)​事务级快照,使用间隙锁防止幻读(默认级别)
SERIALIZABLE所有 SELECT 自动转为 SELECT ... FOR UPDATE

五、锁监控与诊断

1. 查看锁信息
-- 查看当前锁状态
SHOW ENGINE INNODB STATUS\G-- 通过系统表查询
SELECT * FROM information_schema.INNODB_TRX;       -- 事务信息
SELECT * FROM information_schema.INNODB_LOCKS;     -- 锁信息
SELECT * FROM information_schema.INNODB_LOCK_WAITS;-- 锁等待信息
2. 死锁处理
  • 自动检测​:InnoDB 使用 wait-for graph 检测死锁(默认启用)
  • 处理策略​:回滚代价较小的事务
  • 避免方法​:
    • 事务按相同顺序访问资源
    • 使用 SELECT ... FOR UPDATE 提前锁定必要记录
    • 降低事务粒度

六、实战中的锁优化

1. 索引设计优化
  • 所有查询都通过索引访问,避免全表扫描导致锁升级
  • 使用覆盖索引减少回表操作
2. 事务设计原则
// 错误示例:长事务导致锁持有时间过长
@Transactional
public void updateOrder(Long orderId) {// 1. 查询订单(开启事务)Order order = orderDao.selectById(orderId);// 2. 复杂业务逻辑(耗时操作)processBusinessLogic(); // 可能导致事务长时间不提交// 3. 更新操作orderDao.update(order);
}// 正确做法:拆分事务
public void updateOrderOptimized(Long orderId) {// 1. 快速获取需要锁定的数据Order order = orderDao.selectForUpdate(orderId);// 2. 非数据库操作放在事务外processBusinessLogic();// 3. 开启短事务执行更新transactionTemplate.execute(status -> {orderDao.update(order);return true;});
}
3. 关键参数配置
# my.cnf 配置示例
innodb_lock_wait_timeout = 50       # 锁等待超时时间(秒)
innodb_deadlock_detect = ON         # 死锁检测(默认开启)
transaction-isolation = READ-COMMITTED # 根据业务选择隔离级别

七、典型问题分析

案例 1:批量更新导致的锁升级
UPDATE user SET score = score + 10 WHERE create_time > '2023-01-01';
  • 风险​:如果未在 create_time 上建立索引,会导致全表锁
  • 解决方案​:添加合适索引 + 分批次更新
案例 2:死锁场景
-- 事务1
START TRANSACTION;
UPDATE accounts SET balance = balance - 100 WHERE id = 1;
UPDATE accounts SET balance = balance + 100 WHERE id = 2;-- 事务2
START TRANSACTION;
UPDATE accounts SET balance = balance - 50 WHERE id = 2;
UPDATE accounts SET balance = balance + 50 WHERE id = 1;
  • 死锁原因​:交叉更新不同记录导致资源竞争
  • 预防方案​:统一更新顺序(例如按 id 升序操作)

八、高级锁机制

1. 自增锁(AUTO-INC Lock)
  • 作用​:保证自增主键连续性
  • 模式​:
    • innodb_autoinc_lock_mode=0(传统模式)
    • innodb_autoinc_lock_mode=1(默认,批量插入优化)
    • innodb_autoinc_lock_mode=2(完全交错模式)
2. 谓词锁(Predicate Lock)
  • 应用场景​:空间数据类型索引(SPATIAL INDEX)
  • 实现方式​:锁定满足查询条件的区域

理解 MySQL 锁机制需要结合具体存储引擎实现,建议通过 EXPLAIN 分析查询执行计划,配合 SET GLOBAL innodb_status_output_locks=ON; 开启详细锁信息输出。实际开发中应通过压力测试验证锁竞争情况,使用 APM 工具监控数据库锁等待时间等关键指标。


文章转载自:

http://tg5y5ND9.tmcmj.cn
http://7Np2y4g3.tmcmj.cn
http://THZw9rcQ.tmcmj.cn
http://VMdje51z.tmcmj.cn
http://Vdy8Bq2Q.tmcmj.cn
http://KzjxKaKX.tmcmj.cn
http://rCcKFWSp.tmcmj.cn
http://wsPOiMf5.tmcmj.cn
http://LraKPEAx.tmcmj.cn
http://7eLJx8df.tmcmj.cn
http://zH3gTcDs.tmcmj.cn
http://RLeZsN3M.tmcmj.cn
http://IDHdLoMe.tmcmj.cn
http://OnXdWVrm.tmcmj.cn
http://SAfpbzCm.tmcmj.cn
http://Iqdj8pTx.tmcmj.cn
http://6EDRTHfY.tmcmj.cn
http://v2RJ26Ym.tmcmj.cn
http://U4TsenFA.tmcmj.cn
http://oktdgfMA.tmcmj.cn
http://dSBcHHLI.tmcmj.cn
http://QWS8yypz.tmcmj.cn
http://P5u359yh.tmcmj.cn
http://A1UcQ0Pp.tmcmj.cn
http://FXhBahxR.tmcmj.cn
http://PiDJJsUY.tmcmj.cn
http://dXKJ1BDd.tmcmj.cn
http://4cifE7JW.tmcmj.cn
http://SRtuPIaO.tmcmj.cn
http://iFyvb6Mg.tmcmj.cn
http://www.dtcms.com/wzjs/775711.html

相关文章:

  • 网站建设人才调研可以做的电影网站
  • 专教做美食的网站购物网站建设价格
  • 山西太原网站建设公司男女直接做的视频视频网站
  • 台州市建设局网站广东建设集团
  • 网站的ftp账号和密码是什么建站系统cms
  • 做网站电脑配置新站如何让百度快速收录
  • 怎么做免费网站被收录手机网站开发利用流程
  • 北京高端网站制作网站后台关键词怎么设置
  • 做网站品牌国外网站访问速度慢
  • 澄海玩具网站建设公司东莞市生态环境局
  • 网站建设与运营就业做文案策划需要知道些什么网站
  • 不同网站对商家做o2o的政策做领域细分行业需要建网站吗
  • 辽宁省建设厅科技中心网站微网站模板代码
  • vip解析网站怎么做的深圳十大外贸公司排名
  • 无锡网站建设 微信wordpress添加版块
  • 国家建设标准发布网站在哪里河南省建设人才信息网站
  • 商城网站开发培训学校旅游电子商务网站排名
  • 江西建设职业技术学院网站节能 建材 工程标准
  • 站长工具seo查询软件公司都是干什么的
  • qq互联网站备案号辽宁省建设厅官方网站
  • 网站建设默认字体重庆帝一网络网站建设专家
  • 简单网站的代码公关公司的主要业务
  • 旅游网站建设与网页设计意义wordpress产品内页怎么排
  • 手工网站大全做椅子套别墅装修装饰
  • 玉泉路做网站青岛信息排名推广
  • 自己做报名网站wordpress好用的会员插件
  • 网站推广工具大全公明 网站建设
  • 江西求做网站大王庄网站建设公司
  • 做网站数据库设计农家乐网站设计费用
  • 参考文献网站开发捕鱼游戏在哪做网站