MySQL binlog后面的编号如何取值?
哈喽!今天心血来潮给大家带来了《MySQL binlog后面的编号如何取值?》,想必大家应该对文章都不陌生吧,那么阅读本文就都不会很困难,以下内容主要涉及到,若是你正在学习文章,千万别错过这篇文章~希望能帮助到你!
在我们知数堂的MySQL DBA课上讲到binlog序号是从000001开始,这时有细心的同学问到,是不是这个序号达到999999后,binlog就要重新开始了?
讲真,当时我也是一下子被问住了,只是隐约记得这个值是可以大于999999的。于是,课后我自己细致地探究了一番,遂有本文。
MySQL在启动时会扫一下binlog文件,找到最大的序号,然后产生下个序号文件。根据这个规则,我们可以自行测试一下,若当前最大的binlog序号是 999999 时,下一个文件序号是重新从 000001 开始,抑或是 1000000 呢?
把mysqld关掉,人为造出序号为999999的binlog,并直接启动mysqld,看看会怎样呢?
执行 show master status 进行确认
可以看到,mysqld并没有挂掉,也没重新从mysql-bin.000001开始,这个序号会继续增加。
现在,我们再深挖下这个问题,最大的序号到底是多少呢?
我们课上教学使用的版本是mysql 5.7.18,下载相应版本的源码直接看好了,在 sql/binlog.cc 文件中我们找到下面这段代码:
在上面这段代码中,我们看到如下判断:
if (max_found == MAX_LOG_UNIQUE_FN_EXT)
也就是当找到binlog文件最大序号,达到起定义的最大值时,mysqld就会退出。 我们再看下 MAX_LOG_UNIQUE_FN_EXT 宏定义:
#define MAX_LOG_UNIQUE_FN_EXT 0x7FFFFFFF
把它转成十进制看下:
这个值等于:pow(2,31) - 1
手动创建一个序号较大的binlog,比如mysql-bin.2147483640。把所有日志文名都写入到mysql-bin.index 中,并确认 mysql-bin.000001 文件存在(看会不会被覆盖或者其他的)。
然后启动mysqld,再执行 FLUSH LOGS,看看会怎样。
这时,我们能看到 mysqld 启动,日志里记录的告警信息:
我们多执行几次 FLUSH LOGS,切换日志,直到序号达到最大值,看看会发生什么:
第一次切换会发出一个 ERROR 级别错误日志,第二次再切换,直接导致 mysqld 进程退出了。看看错误日志:
看这架势,是想生成 mysql-bin.(1-999) 这样的文件而未果。于是我们再进行下面的测试。
还是 touch 一个较大序号的binlog,比如mysql-bin.2147483646。把所有日志文名都写入到mysql-bin.index 中,并确认 mysql-bin.000001 文件到 mysql-bin.000999 这些文件都不存在(和测试二不同,这次是要确保这些文件不存在,看能不能重复利用)。
然后启动mysqld,再执行 FLUSH LOGS,看看会怎样。
可以看到,还是会退出,并没有进行日志的轮转再次重复利用。
1.binlog的最大序号是pow(2,31)-1=2147483647。
2.当序号接近这个值,且差距小于1000时(也就是序号大于2147482647时),就开始向errorlog中写入警告。
3.当序号达到最大值时,mysqld进程直接退出。
4.生成新的binlog时,会扫描当前已存在的binlog文件,最终取得最大序号值。因此,如果binlog文件数目特别多的话,是会影响MySQL的启动及日志切换效率的。
5.由此可见有两个隐患,当binlog文件数目过大,会导致binlog切换效率较低。当binlog文件最大序号快达到最大值时,离mysqld进程挂掉就不远了,需要加急处理。
6.因此,除了要监控binlog文件数目、最大序号外,还应该再errorlog的内容,都予以足够重视。
今天关于《MySQL binlog后面的编号如何取值?》的内容介绍就到此结束,如果有什么疑问或者建议,可以在golang学习网公众号下多多回复交流;文中若有不正之处,也希望回复留言以告知!

- 上一篇
- RxJS流中筛选偶数并乘以2为何无效?

- 下一篇
- 为什么使用 pytz 将 datetime 对象转换为上海时区时,输出结果比北京时间晚 6 分钟?
-
- 文章 · linux | 4小时前 |
- GitLabLinux版更新维护教程,小白轻松上手变大神!
- 198浏览 收藏
-
- 文章 · linux | 5小时前 |
- Linux手把手教你搭建MinIO存储桶,简单到爆!
- 339浏览 收藏
-
- 文章 · linux | 5小时前 |
- 手把手教你用readdir获取文件修改时间(附代码实例)
- 307浏览 收藏
-
- 文章 · linux | 6小时前 |
- Linux清理命令全掌握,不知道你就out了!
- 197浏览 收藏
-
- 文章 · linux | 6小时前 |
- Linux入门必备!手把手教你搞定用户与组管理
- 467浏览 收藏
-
- 文章 · linux | 7小时前 |
- 手把手教你过滤指定文件类型,超简单教程!
- 455浏览 收藏
-
- 文章 · linux | 7小时前 |
- Linux玩转JS报错?手把手教你轻松解决错误方法
- 427浏览 收藏
-
- 文章 · linux | 7小时前 |
- Hadoop在Linux报错?手把手教你快速定位与解决故障
- 279浏览 收藏
-
- 文章 · linux | 8小时前 |
- 手把手教你用Golang备份Linux日志,效率提升看得见
- 487浏览 收藏
-
- 文章 · linux | 8小时前 |
- Linux找回回收站文件教程,几步教你快速恢复丢失文件
- 491浏览 收藏
-
- 文章 · linux | 8小时前 |
- linux怎么查看cpu信息?超全cpu命令整理!
- 319浏览 收藏
-
- 文章 · linux | 8小时前 |
- LinuxSyslog日志狂飙?手把手教你优化清理
- 393浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 508次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 497次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 茅茅虫AIGC检测
- 茅茅虫AIGC检测,湖南茅茅虫科技有限公司倾力打造,运用NLP技术精准识别AI生成文本,提供论文、专著等学术文本的AIGC检测服务。支持多种格式,生成可视化报告,保障您的学术诚信和内容质量。
- 62次使用
-
- 赛林匹克平台(Challympics)
- 探索赛林匹克平台Challympics,一个聚焦人工智能、算力算法、量子计算等前沿技术的赛事聚合平台。连接产学研用,助力科技创新与产业升级。
- 84次使用
-
- 笔格AIPPT
- SEO 笔格AIPPT是135编辑器推出的AI智能PPT制作平台,依托DeepSeek大模型,实现智能大纲生成、一键PPT生成、AI文字优化、图像生成等功能。免费试用,提升PPT制作效率,适用于商务演示、教育培训等多种场景。
- 90次使用
-
- 稿定PPT
- 告别PPT制作难题!稿定PPT提供海量模板、AI智能生成、在线协作,助您轻松制作专业演示文稿。职场办公、教育学习、企业服务全覆盖,降本增效,释放创意!
- 83次使用
-
- Suno苏诺中文版
- 探索Suno苏诺中文版,一款颠覆传统音乐创作的AI平台。无需专业技能,轻松创作个性化音乐。智能词曲生成、风格迁移、海量音效,释放您的音乐灵感!
- 85次使用
-
- 命令行工具:应对Linux服务器安全挑战的利器
- 2023-10-04 501浏览
-
- 如何使用Docker进行容器的水平伸缩和负载均衡
- 2023-11-07 501浏览
-
- linux .profile的作用是什么
- 2024-04-07 501浏览
-
- 如何解决s权限位引发postfix及crontab异常
- 2024-11-21 501浏览
-
- 如何通过脚本自动化Linux上的K8S安装
- 2025-02-17 501浏览