mysql日志

本文涉及的产品
RDS AI 助手,专业版
RDS Agent(兼容OpenClaw),2核4GB
RDS MySQL DuckDB 分析主实例,集群系列 4核8GB
简介:


mysql日志

mysql有以下几种日志:

错误日志: log-error
查询日志: log
慢查询日志: log-slow-queries
更新日志: log-update
二进制日志: log-bin

主从中继日志:relay_log

 

 

在配置文件中指定log的輸出位置.

# vi /etc/my.cnf

[mysqld]

log-error=/usr/local/mysql/logs/error.log       (指定错误日志存放位置)

log=/usr/local/mysql/logs/sql.log         (对所有执行语句进行记录)

long_query_time=2                 (执行超过2秒的sql会被log下来)

log-slow-queries= /usr/local/mysql/logs/slowquery.log       (将查询返回较慢的语句进行记录)

log-queries-not-using-indexes = nouseindex.log     (log下来没有使用索引的sql语句)

log-bin=/usr/local/mysql/logs/mysql-bin        (设置二进制日志的保存位置,/usr/local/mysql/logs为

路径,mysql-bin为文档前缀,注意给/usr/local/mysql/logs可写入的权限)

expire_logs_day=7                                   (设置二进制日志的保存时间为7天,7天后自动删除

)
    

log_bin=/usr/local/mysql/logs/relaylog      (设置主从mysql中继日志路径为/usr/local/mysql/logs,格

式为relaylog.00001) 

 

:wq

 

 

 
默认情况下,所有日志创建于mysqld数据目录中。

通过刷新日志,你可以强制 mysqld来关闭和重新打开日志文件(或者在某些情况下切换到一个新的日志)。

刷新日志的命令:

> flush logs

# mysqladmin -u root -p flush-logs

# mysqladmin -u root -p refresh


是否启用了日志

mysql> show variables like 'log_%';

怎样知道当前的日志

mysql> show master status;

显示二進制日志数目

mysql> show master logs;

看二进制日志文件用mysqlbinlog

# mysqlbinlog /var/lib/mysql/log/mysql-bin-log.00001

删除全部日志

> reset master;

删除000007编号之前的所有日志

> purge master logs to 'mysql-bin.000007';

删除2012-02-30 23:59:59时间之前的日志

> purge master logs before '2012-02-30 23:59:59';

 

mysql自带了一个查看慢日志的工具mysqldumpslow。

执行mysqldumpslow –h可以查看帮助信息。

主要介绍两个参数-s和-t

-s 这个是排序参数,可选的有:
al: 平均锁定时间
ar: 平均返回记录数
at: 平均查询时间
c: 计数
l: 锁定时间
r: 返回记录
t: 查询时间

-t n 显示头n条记录。

实例:

mysqldumpslow -s c -t 20 host-slow.log           (访问次数最多的20个sql语句)

mysqldumpslow -s r -t 20 host-slow.log           (返回记录集最多的20个sql)

mysqldumpslow -t 10 -s t -g “left join” host-slow.log         (按照时间返回前10条里面含有左连

接的sql语句)


日志恢复:

bin-log是记录着mysql所有事件的操作,当mysql发生灾难性错误时,可以通过bin-log做完整恢复,基于时间

点的恢复,和基于位置的恢复


完整恢复:

假定我们每天凌晨2点都会使用mysqldump备份数据库,但在第二天早上9点由于数据库出现了故障,数据无法访

问,需要恢复数据,先使用昨天凌晨备份的文件进行恢复到凌晨2点的状态,在使用mysqlbinlog恢复自

mysqldump备份以来的binlog
这样数据库就可以完全的恢复到崩溃前的完全状态


基于时间点的恢复:

由于误操作,比如说删除了一张表,这时使用上面讲的完全恢复是没有用的,因为日志里面还存在误操作的语

句,,我们需要的是恢复到误操作前的状态,然后跳过误操作的语句,再恢复后面操作的语句,假定我们删除

了一张表的误操作发生在10:00这个时间点,我们可以使用下面的语句用备份和binlog将数据恢复到故障前

# mysqlbinlog --stop-date='2010-09-04 9:59:59' /var/log/mysql-bin.000001 | mysql -u root -p

然后跳过误操作的时间点,继续执行后面的binlog

# mysqlbinlog --start-date='2010-09-04 10:01:00' /var/log/mysql-bin.000001 | mysql -u root -p 

其中--stop-date='2010-09-04 9:59:59' 和 --start-date='2010-09-04 10:01:00' 其中的时间是你误操作的

时间点,当然了,这个时间点你需要你自己计算的,而且这个时间点还可以涉及到的不只是误操作,还可以有

正确的操作也被跳过去了。


基于位置恢复:

由于上面提到的,使用基于时间点的恢复可能出现,在一个时间点里面可能存在误操作和其他正确的操作,所

以我们需要一种更为精确的恢复方式
使用mysqlbinlog查看二进制,可看到

 

其中drop tables test1这个误操作的end_log_pos为8879917,记下这个id,得出它前后操作的id分别为

8879916,8879918
我们将进行位置恢复操作

# mysqlbinlog --stop-position='8879916' /var/log/mysql-bin.000001 | mysql -u root -p

# mysqlbinlog --start-position='8879918' /var/log/mysql-bin.000001 | mysql -u root -p

第一行是恢复到停止位置位置的所以事务,第二性是恢复从给定的起始位置知道二进制日志结束所有事物。

本文转自linux博客51CTO博客,原文链接http://blog.51cto.com/yangzhiming/834893如需转载请自行联系原作者


yangzhimingg

相关实践学习
每个IT人都想学的“Web应用上云经典架构”实战
本实验从Web应用上云这个最基本的、最普遍的需求出发,帮助IT从业者们通过“阿里云Web应用上云解决方案”,了解一个企业级Web应用上云的常见架构,了解如何构建一个高可用、可扩展的企业级应用架构。
MySQL数据库入门学习
本课程通过最流行的开源数据库MySQL带你了解数据库的世界。   相关的阿里云产品:云数据库RDS MySQL 版 阿里云关系型数据库RDS(Relational Database Service)是一种稳定可靠、可弹性伸缩的在线数据库服务,提供容灾、备份、恢复、迁移等方面的全套解决方案,彻底解决数据库运维的烦恼。 了解产品详情: https://www.aliyun.com/product/rds/mysql 
相关文章
|
9月前
|
SQL 运维 关系型数据库
深入探讨MySQL的二进制日志(binlog)选项
总结而言,对MySQL binlogs深度理解并妥善配置对数据库运维管理至关重要;它不仅关系到系统性能优化也是实现高可靠性架构设计必须考虑因素之一。通过精心规划与周密部署可以使得该机能充分发挥作用而避免潜在风险带来影响。
300 6
|
数据可视化 关系型数据库 MySQL
ELK实现nginx、mysql、http的日志可视化实验
通过本文的步骤,你可以成功配置ELK(Elasticsearch, Logstash, Kibana)来实现nginx、mysql和http日志的可视化。通过Kibana,你可以直观地查看和分析日志数据,从而更好地监控和管理系统。希望这些步骤能帮助你在实际项目中有效地利用ELK来处理日志数据。
974 90
|
SQL 监控 关系型数据库
MySQL日志分析:binlog、redolog、undolog三大日志的深度探讨。
数据库管理其实和写小说一样,需要规划,需要修订,也需要有能力回滚。理解这些日志的作用与优化,就像把握写作工具的使用与运用,为我们的数据库保驾护航。
895 23
|
SQL 运维 关系型数据库
MySQL Binlog 日志查看方法及查看内容解析
本文介绍了 MySQL 的 Binlog(二进制日志)功能及其使用方法。Binlog 记录了数据库的所有数据变更操作,如 INSERT、UPDATE 和 DELETE,对数据恢复、主从复制和审计至关重要。文章详细说明了如何开启 Binlog 功能、查看当前日志文件及内容,并解析了常见的事件类型,包括 Format_desc、Query、Table_map、Write_rows、Update_rows 和 Delete_rows 等,帮助用户掌握数据库变化历史,提升维护和排障能力。
|
存储 SQL 关系型数据库
mysql的undo log、redo log、bin log、buffer pool
MySQL的undo log、redo log、bin log和buffer pool是确保数据库高效、安全和可靠运行的关键组件。理解这些组件的工作原理和作用,对于优化数据库性能和保障数据安全具有重要意义。通过适当的配置和优化,可以显著提升MySQL的运行效率和数据可靠性。
372 16
|
存储 SQL 关系型数据库
mysql的undo log、redo log、bin log、buffer pool
MySQL的undo log、redo log、bin log和buffer pool是确保数据库高效、安全和可靠运行的关键组件。理解这些组件的工作原理和作用,对于优化数据库性能和保障数据安全具有重要意义。通过适当的配置和优化,可以显著提升MySQL的运行效率和数据可靠性。
278 4
|
关系型数据库 MySQL 数据库
MySQL日志
本文介绍了MySQL中三个重要的日志:binlog、redolog和undolog。binlog记录数据库更改操作,支持数据恢复、复制和审计;redolog保证事务的原子性和持久性,实现crash-safe;undolog用于事务回滚及MVCC的实现。每个日志都有其独特的作用和应用场景,确保数据库的稳定性和数据一致性。
303 1
|
SQL 存储 关系型数据库
简单聊聊MySQL的三大日志(Redo Log、Binlog和Undo Log)各有什么区别
在MySQL数据库管理中,理解Redo Log(重做日志)、Binlog(二进制日志)和Undo Log(回滚日志)至关重要。Redo Log确保数据持久性和崩溃恢复;Binlog用于主从复制和数据恢复,记录逻辑操作;Undo Log支持事务的原子性和隔离性,实现回滚与MVCC。三者协同工作,保障事务ACID特性。文章还详细解析了日志写入流程及可能的异常情况,帮助深入理解数据库日志机制。
1926 0
|
监控 安全 Apache
什么是Apache日志?为什么Apache日志分析很重要?
Apache是全球广泛使用的Web服务器软件,支持超过30%的活跃网站。它通过接收和处理HTTP请求,与后端服务器通信,返回响应并记录日志,确保网页请求的快速准确处理。Apache日志分为访问日志和错误日志,对提升用户体验、保障安全及优化性能至关重要。EventLog Analyzer等工具可有效管理和分析这些日志,增强Web服务的安全性和可靠性。
618 9

推荐镜像

更多