首页 » PHP教程 » php0179技巧_区区1万张表就把MySQL给整崩溃了

php0179技巧_区区1万张表就把MySQL给整崩溃了

访客 2024-10-23 0

扫一扫用手机浏览

文章目录 [+]

Percona 资深工程师 Marco Tusa 近日爆料称,升级到 MySQL 8.0.38 版本后,当实例中的表个数超过一万个,实例重启后会发生 Crash 而失落败,即便是重启时加上 validate_tablespace_paths=OFF 也弗成。

这个问题在 >= 8.0.38 版本中存在,包括 8.4.1 和 9.0.0。

php0179技巧_区区1万张表就把MySQL给整崩溃了

详细复现过程拜会:https://perconadev.atlassian.net/browse/PS-9306。

php0179技巧_区区1万张表就把MySQL给整崩溃了
(图片来自网络侵删)

用 MySQL 9.0.0 版本测试:

-- 创建一个最大略的表,并写入数据> CREATE DATABASE test;> USE test;> CREATE TABLE t_1 ( `id` int NOT NULL, PRIMARY KEY (`id`));> INSERT INTO t_1 SELECT 1;

然后反复创建类似上面的表,表个数达到 1 万。

> SELECT COUNT() FROM information_schema.tables WHERE TABLE_SCHEMA ='test';+----------+| count() |+----------+| 10000 |+----------+

之后重启实例,就能看到日志里有类似下面的内容,启动失落败:

[Note] [MY-012207] [InnoDB] Using 2 threads to scan 10002 tablespace files[Note] [MY-012200] [InnoDB] Thread# 0 - Checked 876/10002 files...[Note] [MY-012201] [InnoDB] Checked 10002 files[Note] [MY-012208] [InnoDB] Completed space ID check of 10004 files....2024-07-12T06:48:14Z UTC - mysqld got signal 11 ;Signal SIGSEGV (Address not mapped to object) at address 0x508Most likely, you have hit a bug, but this error can also be caused by malfunctioning hardware.BuildID[sha1]=7f06a4743d7801096bd81bc999201fdbca43a12cThread pointer: 0x0Attempting backtrace. You can use the following information to find outwhere mysqld died. If you see no messages after this, something wentterribly wrong...stack_bottom = 0 thread_stack 0x100000[root@db160 mysql-9.0.0-linux-glibc2.17-x86_64-minimal]# #0 0x103f726 <unknown> #1 0x103fa8c <unknown> #2 0x7f18f666ac1f <unknown> at sysdeps/unix/sysv/linux/x86_64/sigaction.c:0 #3 0x218a7be <unknown> #4 0x21705a7 <unknown> #5 0x2b1d263 <unknown> #6 0x7f18f6660179 start_thread at /usr/src/debug/glibc-2.28/nptl/pthread_create.c:479 #7 0x7f18f4811dc2 <unknown> at sysdeps/unix/sysv/linux/x86_64/clone.S:95 #8 0xffffffffffffffff <unknown>The manual page at http://dev.mysql.com/doc/mysql/en/crashing.html containsinformation that should help you find out what is causing the crash.

确实挺拉胯的。

除了上面的测试用例,还测试了几种环境:

1、从 8.0.38 降级到 8.0.37、36、35 都是OK的,可以重新拉起,不报错;

2、拉起后删掉多余的表后再次用 8.0.38 也可以拉起;再次降级回 8.0.35 后又升级回 8.0.38 还是正常。

结论:

1、8.0.35 - 8.0.38 间可以反复升级、降级操作不影响,仅限我的测试场景,更繁芜场景不能担保也 OK。

2、降级到 8.0.34 后就开始跪了,没再连续往下测试。

MySQL 8.0 手册和 release notes 里都没有说许可 8.0.35-8.0.38 间相互升降级,但目前大略测试是 OK 的。

当然,还是有办法可以规避的,也便是采取 共享/通用 表空间方案,例如:

-- 1. 共享表空间方案> SET GLOBAL innodb_file_per_table = 0;> CREATE TABLE ...;-- 2. 通用表空间方案> CREATE TABLESPACE test ADD DATAFILE 'test.ibd';> CREATE TABLE t_1(...) TABLESPACE=test;

上述方案我已履历证过。

说下我个人意见,这个 Bug 虽很 low,但这个问题很小,也很随意马虎规避。

MySQL 最近表现确实很辣鸡,但我依然热爱它 。


这算不算罗曼罗兰说的那种英雄主义,咱便是这么乐不雅观,哈哈哈。

末了,看看 AliSQL 的内核开拓者对引发此问题的 bug (#bug115517) 进行的深入剖析。
他曾在 AliSQL 上做了海量表场景下的启动优化,使百万表 Recovery 启动韶光从 500 多秒缩短到 20 多秒。

详情查看:https://bugs.mysql.com/bug.php?id=115569

标签:

相关文章

执业药师试卷代码解码药师职业发展之路

执业药师在药品质量管理、用药安全等方面发挥着越来越重要的作用。而执业药师考试,作为进入药师行业的重要门槛,其试卷代码更是成为了药师...

PHP教程 2025-02-18 阅读1 评论0

心灵代码主题曲唤醒灵魂深处的共鸣

音乐,作为一种独特的艺术形式,自古以来就承载着人类情感的表达与传递。心灵代码主题曲,以其独特的旋律和歌词,唤醒了无数人的灵魂深处,...

PHP教程 2025-02-18 阅读1 评论0

探寻福建各市车牌代码背后的文化内涵

福建省,地处我国东南沿海,拥有悠久的历史和丰富的文化底蕴。在这片充满魅力的土地上,诞生了许多具有代表性的城市,每个城市都有自己独特...

PHP教程 2025-02-18 阅读1 评论0

探寻河北唐山历史与现代交融的城市之光

河北省唐山市,一座地处渤海之滨,拥有悠久历史和独特文化的城市。这里既是古丝绸之路的起点,也是中国近代工业的发源地。如今,唐山正以崭...

PHP教程 2025-02-18 阅读1 评论0