MySQL因为hung住,自动重新启动,InnoDB: Semaphore wait has lasted > 600 seconds

本文涉及的产品
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
RDS AI 助手,专业版
简介: 从错误日志中检查,有两个信号量等待时间超长,MySQL自动crash了

从错误日志中检查,有两个信号量等待时间超长,MySQL自动crash了:

# grep " 600 " 31-226-mysql-error.log 
2021-12-27T02:25:15.086231Z 0 [ERROR] [FATAL] InnoDB: Semaphore wait has lasted > 600 seconds. We intentionally crash the server because it appears to be hung.
2021-12-27T03:22:41.057752Z 0 [ERROR] [FATAL] InnoDB: Semaphore wait has lasted > 600 seconds. We intentionally crash the server because it appears to be hung.
# grep "ready for connections" 31-226-mysql-error.log 
2021-12-27T02:57:54.430405Z 0 [Note] /usr/sbin/mysqld: ready for connections.
2021-12-27T04:01:35.813766Z 0 [Note] /usr/sbin/mysqld: ready for connections.


srv_error_monitor_thread发现存在阻塞超过600s的latch锁时,如果连续多次检测该锁仍没有释放,就会触发自动crash,避免MySQL持续hung住。

检查等待信息量时间长的线程有3个:


# grep "Thread 140487646721792 " 31-226-mysql-error.log 
--Thread 140487646721792 has waited at buf0buf.cc line 3975 for 241  seconds the semaphore:
--Thread 140487646721792 has waited at buf0buf.cc line 3975 for 244  seconds the semaphore:
--Thread 140487646721792 has waited at buf0buf.cc line 3975 for 264  seconds the semaphore:
......
--Thread 140487646721792 has waited at buf0buf.cc line 3975 for 923  seconds the semaphore:
--Thread 140487646721792 has waited at buf0buf.cc line 3975 for 924  seconds the semaphore:
--Thread 140487646721792 has waited at buf0buf.cc line 3975 for 944  seconds the semaphore:
# grep "Thread 140487338841856" 31-226-mysql-error.log 
--Thread 140487338841856 has waited at buf0buf.cc line 3975 for 241  seconds the semaphore:
--Thread 140487338841856 has waited at buf0buf.cc line 3975 for 244  seconds the semaphore:
--Thread 140487338841856 has waited at buf0buf.cc line 3975 for 264  seconds the semaphore:
--Thread 140487338841856 has waited at buf0buf.cc line 3975 for 272  seconds the semaphore:
.......
--Thread 140487338841856 has waited at buf0buf.cc line 3975 for 923  seconds the semaphore:
--Thread 140487338841856 has waited at buf0buf.cc line 3975 for 924  seconds the semaphore:
--Thread 140487338841856 has waited at buf0buf.cc line 3975 for 944  seconds the semaphore:


# grep "Thread 140487643309824" 31-226-mysql-error.log 
--Thread 140487643309824 has waited at buf0buf.cc line 3975 for 241  seconds the semaphore:
--Thread 140487643309824 has waited at buf0buf.cc line 3975 for 244  seconds the semaphore:
--Thread 140487643309824 has waited at buf0buf.cc line 3975 for 264  seconds the semaphore:
......
--Thread 140487643309824 has waited at buf0buf.cc line 3975 for 923  seconds the semaphore:
--Thread 140487643309824 has waited at buf0buf.cc line 3975 for 924  seconds the semaphore:
--Thread 140487643309824 has waited at buf0buf.cc line 3975 for 944  seconds the semaphore:


这3个线程都出现了58次等待信号量,查询系统的信号量:

# cat /proc/sys/kernel/sem
250 32000 32  128


说明:

第一列,表示每个信号集中的最大信号量数目。

第二列,表示系统范围内的最大信号量总数目。

第三列,表示每个信号发生时的最大系统操作数目。

第四列,表示系统范围内的最大信号集总数目。


增大信号量只能治标,不治本,实际上还是数据库中有效率底下的SQL语句,优化SQL才是正解!

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
9月前
|
存储 网络协议 关系型数据库
MySQL8.4创建keyring给InnoDB表进行静态数据加密
MySQL8.4创建keyring给InnoDB表进行静态数据加密
363 1
|
4月前
|
存储 关系型数据库 MySQL
介绍MySQL的InnoDB引擎特性
总结而言 , Inno DB 引搞 是 MySQL 中 高 性 能 , 高 可靠 的 存 储选项 , 宽泛 应用于要求强 复杂交易处理场景 。
203 15
|
存储 缓存 关系型数据库
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
MySQL的存储引擎是其核心组件之一,负责数据的存储、索引和检索。不同的存储引擎具有不同的功能和特性,可以根据业务需求 选择合适的引擎。本文详细介绍了MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案。
2134 57
【MySQL进阶篇】存储引擎(MySQL体系结构、InnoDB、MyISAM、Memory区别及特点、存储引擎的选择方案)
|
9月前
|
SQL 缓存 关系型数据库
使用温InnoDB缓冲池启动MySQL测试
使用温InnoDB缓冲池启动MySQL测试
183 0
|
存储 关系型数据库 MySQL
MySQL存储引擎详述:InnoDB为何胜出?
MySQL 是最流行的开源关系型数据库之一,其存储引擎设计是其高效灵活的关键。InnoDB 作为默认存储引擎,支持事务、行级锁和外键约束,适用于高并发读写和数据完整性要求高的场景;而 MyISAM 不支持事务,适合读密集且对事务要求不高的应用。根据不同需求选择合适的存储引擎至关重要,官方推荐大多数场景使用 InnoDB。
597 7
|
存储 关系型数据库 MySQL
Mysql索引:深入理解InnoDb聚集索引与MyisAm非聚集索引
通过本文的介绍,希望您能深入理解InnoDB聚集索引与MyISAM非聚集索引的概念、结构和应用场景,从而在实际工作中灵活运用这些知识,优化数据库性能。
637 7
|
存储 关系型数据库 MySQL
MySQL引擎InnoDB和MyISAM的区别?
InnoDB是MySQL默认的事务型存储引擎,支持事务、行级锁、MVCC、在线热备份等特性,主索引为聚簇索引,适用于高并发、高可靠性的场景。MyISAM设计简单,支持压缩表、空间索引,但不支持事务和行级锁,适合读多写少、不要求事务的场景。
259 9
|
存储 关系型数据库 MySQL
MySQL数据库进阶第六篇(InnoDB引擎架构,事务原理,MVCC)
MySQL数据库进阶第六篇(InnoDB引擎架构,事务原理,MVCC)
|
存储 Oracle 关系型数据库
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件
本文介绍了MySQL InnoDB存储引擎中的数据文件和重做日志文件。数据文件包括`.ibd`和`ibdata`文件,用于存放InnoDB数据和索引。重做日志文件(redo log)确保数据的可靠性和事务的持久性,其大小和路径可由相关参数配置。文章还提供了视频讲解和示例代码。
394 11
【赵渝强老师】MySQL InnoDB的数据文件与重做日志文件

推荐镜像

更多