一路走来,所有遇到的人,帮助过我的、伤害过我的都是朋友,没有一个是敌人,如有侵权请留言,我及时删除。
一、mysql相关日志
首先,我们能接触到的,一般我们排查慢查询时,会去看慢查询日志。如果做过数据备份会恢复的,可能接触或用过BinLog。那还有其他的吗?对MySQL原理比较了解的,应该知道还有Redo Log和Undo Log。这些都是比较常见:慢查询日志、Binlog、Redo Log、Undo Log。
其实,MySQL中还有:错误日志(errorlog)、一般查询日志(general log)、中继日志(relay log),只是这些大家接触少点。
总结下,MySQL中一共七种日志,分别为:慢查询日志、Binlog、Redo Log、Undo Log、错误日志(errorlog)、一般查询日志(general log)、中继日志(relay log)。
data:image/s3,"s3://crabby-images/bd6b3/bd6b30c4a26b6f0d6cae17f567128998424b92b9" alt=""
1、错误日志 log_error
data:image/s3,"s3://crabby-images/6e947/6e947b5a7c4893948c56b190f932b70414e354d3" alt=""
mysql> show variables like '%log_error%';
data:image/s3,"s3://crabby-images/33171/33171a5018324e9cd484bf3ee722277e10957700" alt=""
2、二进制日志 BINLOG
data:image/s3,"s3://crabby-images/59793/59793774ac8897d96743cad2f7d883fda62422cb" alt=""
mysql> show variables like '%bin_log%';
data:image/s3,"s3://crabby-images/9ac64/9ac64d6a7bb6f7e7d84527af3f43c6467da58517" alt=""
2.1、使用mysqlbinlog 查看MySQL默认的二进制格式
data:image/s3,"s3://crabby-images/4810e/4810ed49fd887f9907252dd0d350d51b5142528d" alt=""
mysql binlog参数详解_mysqlbinlog参数-CSDN博客
mysql> show variables like '%binlog_format%';
data:image/s3,"s3://crabby-images/50c35/50c35409505e5e42dd8cf3f74368f947753cee68" alt=""
使用mysqlbinlog 查看MySQL binlog ROW格式的二进制日志
示例:创建一张销售表,并在binlog日志中找到SQL执行记录
CREATE TABLE sales (
id INT PRIMARY KEY AUTO_INCREMENT,
product VARCHAR(50),
quantity INT,
price DECIMAL(10,2)
);
INSERT INTO sales (product, quantity, price) VALUES ('产品A', 10, 9.99);
INSERT INTO sales (product, quantity, price) VALUES ('产品B', 5, 4.99);
INSERT INTO sales (product, quantity, price) VALUES ('产品C', 8, 6.75);
[root@mysql8 data]# mysqlbinlog -v binlog.000007
2.2、使用mysqlbinlog 查看MySQL binlog STATEMENT格式的二进制日志
配置文件/etc/my.cnf 新增 binlog_format=STATEMENT 重启MySQL
vi /etc/my.cnf
binlog_format=STATEMENT
data:image/s3,"s3://crabby-images/d5cb5/d5cb53ddcd8d86d890e44e543964c3a95b373bb4" alt=""
插入一条语句,并在binlog日志中查看执行的SQL
INSERT INTO sales (product, quantity, price) VALUES ('??D', 9, 8.75)
data:image/s3,"s3://crabby-images/82296/82296169e5a92951389b8a5e628d9f4352643205" alt=""
2.3、清理MySQL-binlog日志文件
data:image/s3,"s3://crabby-images/17818/17818c7a46d0e4e12aabafbb61a321ac5655c1ae" alt=""
示例一:删除binlog.000003之前的日志
mysql> purge master logs to 'binlog.000003';
data:image/s3,"s3://crabby-images/b7754/b775430769c5bcdd7b2851dccf6597db59b458dd" alt=""
data:image/s3,"s3://crabby-images/02c94/02c947bc584a3b3b7dba98c581aa52b4ebd08643" alt=""
2.4、MySQL数据设置binlog日志过期时间
mysql> show variables like '%binlog_expire_logs%';
data:image/s3,"s3://crabby-images/7dc72/7dc72ceccab6acb1ba785738e6334ca701bfa849" alt=""
3、MySQL 查询日志
data:image/s3,"s3://crabby-images/e818b/e818bebe99eb2d6e84ebbff0eca49422cbb3cf0f" alt=""
3.1、查询日志默认状态
mysql> show variables like '%general%';
data:image/s3,"s3://crabby-images/aeead/aeeadb0b99e4f80c34da1c4a3f8ae3a83e5c9815" alt=""
3.2、开启MySQL查询日志,修改my.cnf文件,并重启MySQL服务
vi /etc/my.cnf
---新增如下配置-------
general_log=1
general_log_file=/mysql/data/mysql8.log
[root@mysql8 data]# systemctl restart mysqld
查看日志状态
mysql> show variables like '%general%';
data:image/s3,"s3://crabby-images/167b4/167b496caf49f4bb588665347ae36f43dca8cfb0" alt=""
3.3、查询日志记录的信息
data:image/s3,"s3://crabby-images/31245/312459cec09bd23145bf729bc98d26d80df786de" alt=""
data:image/s3,"s3://crabby-images/71fab/71fab4f329a7a00f970f27e932f91058ad7ec7f5" alt=""
data:image/s3,"s3://crabby-images/07f37/07f371015004429a1ed4425f5622b81e400c7e00" alt=""
4、慢日志
data:image/s3,"s3://crabby-images/f04a6/f04a66541903b3984517714baac9e1e7a62655fa" alt=""
4.1、查看慢日志的默认配置
data:image/s3,"s3://crabby-images/bc290/bc2902b1b04904388286bddc097c5ebfff00bd1c" alt=""
4.2、开启慢日志,并修改慢SQL记录时间,重启MySQL生效
[root@mysql8 data]# vi /etc/my.cnf
----新增配置-----
slow_query_log=1
long_query_time=1
[root@mysql8 data]# systemctl restart mysqld
data:image/s3,"s3://crabby-images/6b643/6b643aa9ae184c974b97404195c055f18f2d5d8e" alt=""
4.3、准备测试环境,创建一个1千万数据的test 表
data:image/s3,"s3://crabby-images/bca44/bca4464feab81191c03dde3857939bb9f6ac0e12" alt=""
【MySQL】生成1000万条测试数据_生成1000w条mysql数据-CSDN博客
data:image/s3,"s3://crabby-images/ee474/ee474bbbd3047118bb4e49b1e2f1d1ef2629194c" alt=""