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 | 9小时前 |
- Linux虚拟化教程:KVM与QEMU搭建指南
- 282浏览 收藏
-
- 文章 · linux | 10小时前 |
- Linux日志审计技巧与安全分析
- 136浏览 收藏
-
- 文章 · linux | 10小时前 |
- Linux多用户资源管理与cgroups限制解析
- 113浏览 收藏
-
- 文章 · linux | 10小时前 |
- Linux性能排查技巧:perf与top实战教程
- 278浏览 收藏
-
- 文章 · linux | 11小时前 |
- Linux多用户资源管理:cgroups限制策略详解
- 448浏览 收藏
-
- 文章 · linux | 12小时前 |
- Linux服务器物理安全防护指南
- 255浏览 收藏
-
- 文章 · linux | 14小时前 |
- Linux权限递归修改教程:chmod与chown详解
- 421浏览 收藏
-
- 文章 · linux | 14小时前 |
- Linux镜像源选择与设置教程
- 491浏览 收藏
-
- 文章 · linux | 15小时前 |
- Linux安全指南:实用杀毒工具与防护策略
- 247浏览 收藏
-
- 文章 · linux | 15小时前 |
- LinuxPAM配置技巧与安全指南
- 443浏览 收藏
-
- 文章 · linux | 16小时前 |
- Linux下K8s集群搭建教程详解
- 403浏览 收藏
-
- 文章 · linux | 16小时前 |
- Linux内存优化技巧及内核机制详解
- 163浏览 收藏
-
- 前端进阶之JavaScript设计模式
- 设计模式是开发人员在软件开发过程中面临一般问题时的解决方案,代表了最佳的实践。本课程的主打内容包括JS常见设计模式以及具体应用场景,打造一站式知识长龙服务,适合有JS基础的同学学习。
- 542次学习
-
- GO语言核心编程课程
- 本课程采用真实案例,全面具体可落地,从理论到实践,一步一步将GO核心编程技术、编程思想、底层实现融会贯通,使学习者贴近时代脉搏,做IT互联网时代的弄潮儿。
- 511次学习
-
- 简单聊聊mysql8与网络通信
- 如有问题加微信:Le-studyg;在课程中,我们将首先介绍MySQL8的新特性,包括性能优化、安全增强、新数据类型等,帮助学生快速熟悉MySQL8的最新功能。接着,我们将深入解析MySQL的网络通信机制,包括协议、连接管理、数据传输等,让
- 498次学习
-
- JavaScript正则表达式基础与实战
- 在任何一门编程语言中,正则表达式,都是一项重要的知识,它提供了高效的字符串匹配与捕获机制,可以极大的简化程序设计。
- 487次学习
-
- 从零制作响应式网站—Grid布局
- 本系列教程将展示从零制作一个假想的网络科技公司官网,分为导航,轮播,关于我们,成功案例,服务流程,团队介绍,数据部分,公司动态,底部信息等内容区块。网站整体采用CSSGrid布局,支持响应式,有流畅过渡和展现动画。
- 484次学习
-
- 千音漫语
- 千音漫语,北京熠声科技倾力打造的智能声音创作助手,提供AI配音、音视频翻译、语音识别、声音克隆等强大功能,助力有声书制作、视频创作、教育培训等领域,官网:https://qianyin123.com
- 165次使用
-
- MiniWork
- MiniWork是一款智能高效的AI工具平台,专为提升工作与学习效率而设计。整合文本处理、图像生成、营销策划及运营管理等多元AI工具,提供精准智能解决方案,让复杂工作简单高效。
- 161次使用
-
- NoCode
- NoCode (nocode.cn)是领先的无代码开发平台,通过拖放、AI对话等简单操作,助您快速创建各类应用、网站与管理系统。无需编程知识,轻松实现个人生活、商业经营、企业管理多场景需求,大幅降低开发门槛,高效低成本。
- 167次使用
-
- 达医智影
- 达医智影,阿里巴巴达摩院医疗AI创新力作。全球率先利用平扫CT实现“一扫多筛”,仅一次CT扫描即可高效识别多种癌症、急症及慢病,为疾病早期发现提供智能、精准的AI影像早筛解决方案。
- 168次使用
-
- 智慧芽Eureka
- 智慧芽Eureka,专为技术创新打造的AI Agent平台。深度理解专利、研发、生物医药、材料、科创等复杂场景,通过专家级AI Agent精准执行任务,智能化工作流解放70%生产力,让您专注核心创新。
- 180次使用
-
- 命令行工具:应对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浏览