0

0

mysql数据库日志文件有什么作用_mysql日志基础解析

P粉602998670

P粉602998670

发布时间:2026-02-21 08:24:36

|

206人浏览过

|

来源于php中文网

原创

错误日志是排障第一现场,记录mysql启动失败、连接被拒等关键错误;binlog用于主从复制和时间点恢复;慢日志捕获超时sql;redo log保障崩溃恢复;undo log支撑mvcc和事务回滚。

mysql数据库日志文件有什么作用_mysql日志基础解析

错误日志(error log)是排障第一现场

MySQL一启动失败、连接被拒、表损坏或磁盘写满,错误日志里立刻有记录。它不像其他日志可开关,只要MySQL在跑,就默认写入——这是你查“为什么连不上”“为什么服务起不来”的第一站。

常见错误现象:Can't start server: Bind on TCP/IP port(端口被占)、Table 'xxx' is marked as crashed(表损坏)、Out of memory(OOM)。这些不会出现在慢日志或binlog里,只在这里。

实操建议:

  • SHOW VARIABLES LIKE 'log_error'; 查日志路径,别猜 /var/log/mysql/error.log/var/lib/mysql/hostname.err
  • 日志不自动轮转,生产环境务必配 log_error_services = 'log_filter_dragnet; log_sink_syseventlog'(MySQL 8.0.30+)或用外部工具(如logrotate)切分,否则单文件可能涨到几十GB
  • 别依赖 tail -f 实时盯屏——MySQL崩溃时可能来不及刷盘,要加 sync_log=ON(仅限调试,性能敏感场景慎开)

二进制日志(binlog)不是备份,但没它就做不了时间点恢复

binlog 记的是“做了什么”,不是“数据长什么样”。它不记录 SELECT,只记 DML(INSERT/UPDATE/DELETE)和 DDL(CREATE/ALTER),是主从复制和基于位置的恢复(PITR)唯一依据。

容易踩的坑:

NotebookLM
NotebookLM

Google推出的AI笔记应用工具

下载
  • sql_log_bin=OFF 会跳过当前会话的所有 binlog 写入——执行误删语句前关了它,等于自废恢复武功
  • 格式选错:用 STATEMENT 遇上 NOW()RAND()UUID(),主从数据必然不一致;ROW 安全但体积大,批量 UPDATE 百万行可能生成几百MB日志
  • 过期配置 binlog_expire_logs_seconds 是按写入时间算,不是按文件名序号——重启频繁的测试库,旧日志可能早被删光,别等出事才查

慢查询日志(slow query log)不是性能报告,而是SQL问题的原始证据链

它不分析原因,只忠实记录超时的语句+执行计划基础信息(如是否用了索引、扫描行数)。真正价值在于:把“这个接口变慢了”和“某条SQL执行了12.7秒”建立确定性关联。

使用场景与注意点:

  • 阈值 long_query_time 默认是10秒,线上建议调成 10.5;设为 0 可捕获所有查询,但IO压力陡增,仅限短时诊断
  • 日志输出方式影响排查效率:log_output='FILE' 适合 grep + mysqldumpslow 分析;log_output='TABLE'(写入 mysql.slow_log)方便 SQL 统计,但表结构无索引,查历史数据极慢
  • 记得开 log_queries_not_using_indexes=ON——很多“不慢”的SQL其实正在全表扫描,只是数据量小没暴露,这是隐形性能债

重做日志(redo log)和回滚日志(undo log)不在磁盘目录里,但决定你敢不敢关机

它们是InnoDB引擎私有日志,不归MySQL Server管,也不在 datadir 下以明文文件存在(ib_logfile0/1 是 redo,ibdata1 里混存 undo)。你感知不到它们,除非遇到崩溃恢复失败或长事务卡住 purge 线程。

关键事实:

  • redo log 保证 crash-safe:事务提交时只要写入 redo(刷盘或仅进 OS cache),断电重启也能重放;但它不负责主从同步,那是 binlog 的事
  • undo log 不是“用来回滚的快照”,而是MVCC多版本读的基础——SELECT 要读历史版本时,靠的就是它;长事务不提交,undo 日志不能回收,ibdata1 就会持续膨胀
  • 别手动删 ib_logfile*!MySQL 启动时校验 size 和 checkpoint,删了轻则拒绝启动,重则数据页损坏

真正复杂的从来不是“怎么开日志”,而是理解每种日志的职责边界——比如 binlog 能恢复到秒级,但救不了误 drop 的表;redo log 能保事务不丢,但救不了被覆盖的 binlog 文件。日志不是万能胶,是分工明确的齿轮组。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
数据分析工具有哪些
数据分析工具有哪些

数据分析工具有Excel、SQL、Python、R、Tableau、Power BI、SAS、SPSS和MATLAB等。详细介绍:1、Excel,具有强大的计算和数据处理功能;2、SQL,可以进行数据查询、过滤、排序、聚合等操作;3、Python,拥有丰富的数据分析库;4、R,拥有丰富的统计分析库和图形库;5、Tableau,提供了直观易用的用户界面等等。

1006

2023.10.12

SQL中distinct的用法
SQL中distinct的用法

SQL中distinct的语法是“SELECT DISTINCT column1, column2,...,FROM table_name;”。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

334

2023.10.27

SQL中months_between使用方法
SQL中months_between使用方法

在SQL中,MONTHS_BETWEEN 是一个常见的函数,用于计算两个日期之间的月份差。想了解更多SQL的相关内容,可以阅读本专题下面的文章。

378

2024.02.23

SQL出现5120错误解决方法
SQL出现5120错误解决方法

SQL Server错误5120是由于没有足够的权限来访问或操作指定的数据库或文件引起的。想了解更多sql错误的相关内容,可以阅读本专题下面的文章。

1782

2024.03.06

sql procedure语法错误解决方法
sql procedure语法错误解决方法

sql procedure语法错误解决办法:1、仔细检查错误消息;2、检查语法规则;3、检查括号和引号;4、检查变量和参数;5、检查关键字和函数;6、逐步调试;7、参考文档和示例。想了解更多语法错误的相关内容,可以阅读本专题下面的文章。

376

2024.03.06

oracle数据库运行sql方法
oracle数据库运行sql方法

运行sql步骤包括:打开sql plus工具并连接到数据库。在提示符下输入sql语句。按enter键运行该语句。查看结果,错误消息或退出sql plus。想了解更多oracle数据库的相关内容,可以阅读本专题下面的文章。

1332

2024.04.07

sql中where的含义
sql中where的含义

sql中where子句用于从表中过滤数据,它基于指定条件选择特定的行。想了解更多where的相关内容,可以阅读本专题下面的文章。

585

2024.04.29

sql中删除表的语句是什么
sql中删除表的语句是什么

sql中用于删除表的语句是drop table。语法为drop table table_name;该语句将永久删除指定表的表和数据。想了解更多sql的相关内容,可以阅读本专题下面的文章。

436

2024.04.29

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

796

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
MySQL 教程
MySQL 教程

共48课时 | 2.3万人学习

MySQL 初学入门(mosh老师)
MySQL 初学入门(mosh老师)

共3课时 | 0.3万人学习

简单聊聊mysql8与网络通信
简单聊聊mysql8与网络通信

共1课时 | 835人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号