Loading [MathJax]/jax/output/CommonHTML/config.js
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >Mysql 日志管理(学习笔记九)

Mysql 日志管理(学习笔记九)

作者头像
用户5760343
发布于 2022-05-23 09:45:40
发布于 2022-05-23 09:45:40
4870
举报
文章被收录于专栏:sktjsktj

mysql日志——记录着mysql数据库运行期间的操作和信息

日志作用

(1)当数据库遭到意外损害,可以通过日志文件来查询出错原因

(2)利用日志文件进行数据恢复

日志分类

(1)二进制日志:以二进制文件的形式记录了数据库中的操作,但是不记录查询语句

(2)错误日志:记录Mysql服务器的启动、关闭和运行错误等信息

(3)慢查询日志:记录执行时间超过指定时间的操作

(4)通用查询日志:记录用户的所有操作,包括启动和关闭MySQL服务、更新语句、查询语句等

日志设置

(1)除了二进制日志,其他都是文本文件

(2)日志文件通常存储在Mysql数据目录下

(3)默认只启动了错误日志功能,其他需要手工启动

(4)但启动日志功能会降低Mysql的执行速度,因为一条操作写进日志中是要花时间的

二进制日志

(1) 以二进制文件的形式记录了数据库中的操作,但是不记录查询语句

(2) 也叫变更日志(update log),主要用于记录数据库的变化

(3) 启动与设置二进制日志:在Mysql的配置文件中,log-bin=DIR/filename

DIR是存放二进制日志的目录;

每启动一次Mysql,该目录下就会生成一个filename.00000x的文件;

目录下还有一个filename.index的文件,用于存储所有二进制文件清单;

如果我们没有设置DIR和filename,则默认在数据目录下以hostname-bin.00000x命名

# cat /etc/my.cnf|egrep "log-bin"

log-bin = /data/mysqldb/binlog/mysql-bin

# ls /data/mysqldb/binlog/

mysql-bin.000001 mysql-bin.000003 mysql-bin.000005 mysql-bin.000007 mysql-bin.index

mysql-bin.000002 mysql-bin.000004 mysql-bin.000006 mysql-bin.000008

(4)临时停止与启动二进制日志

-> set sql_log_bin=0; 停止-> set sql_log_bin=1; 启动

(5)注意:二进制日志文件与数据库数据文件最好不要放在同一块硬盘上,如果存放数据文件的硬盘坏了,可以用另一块硬盘的二进制日志来恢复数据

(6)查看二进制日志:

# mysqlbinlog mysql-bin.000001

(7)删除二进制日志:

//删除所有->reset master;//删除00004之前的所有->purge master logs to'mysql-bin.000004';//删除指定日期时间之前的所有->purge master logs to'2016-08-10 15:00:00';

(8)使用二进制日志还原数据库

# mysqlbinlog mysql-bin.000001 | mysql -u root -p

# mysqlbinlog mysql-bin.000002 |mysql -u root -p

这条命令可以理解为:使用mysqlbinlog读取二进制日志文件然后使用mysql命令还原到数据库中

注意还原时必须是编号小的先还原

(9)使用二进制日志文件的pos号|时间点恢复

//先执行3条操作-> create database 2test-> create database alvin-> drop database 2test//查看二进制日志,观察每一个命令的起始/结束pos号,和起始/结束时间# mysqlbinlog mysql-bin.000001# at 120#160813 15:13:53serverid 706end_log_pos 217CRC32 0x781f816eQuery    thread_id=21exec_time=0 error_code=0SET TIMESTAMP=1471072433/*!*/;

SET @@session.pseudo_thread_id=21/*!*/;

SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1/*!*/;

SET @@session.sql_mode=1075838976/*!*/;

SET @@session.auto_increment_increment=1, @@session.auto_increment_offset=1/*!*/;

/*!\C utf8 *//*!*/;

SET @@session.character_set_client=33,@@session.collation_connection=33,@@session.collation_server=33/*!*/;SET @@session.lc_time_names=0/*!*/;SET @@session.collation_database=DEFAULT/*!*/;create database 2test/*!*/;# at 217#160813 15:14:11serverid 706end_log_pos 314 CRC32 0x0fde9820Query    thread_id=21exec_time=0error_code=0SET TIMESTAMP=1471072451/*!*/;create database alvin/*!*/;//想回到什么哪条命令时的状态,可以指定起始/结束pos号恢复# mysqlbinlog --start-position="120" --stop-position="217" mysql-bin.000001 |mysql -u root -p

//日志也会记录下这条恢复语句,我们可以看到这条命令的时间和原来那条一模一样

# mysqlbinlog mysql-bin.000001# at 401#160813 15:13:53server id 706 end_log_pos 498 CRC32 0x3a899ca5 Query    thread_id=21    exec_time=619    error_code=0SET TIMESTAMP=1471072433/*!*/;create database 2test/*!*/;

//同理也可以用时间点来恢复

# mysqlbinlog –start-datetime=”2016-08-13 15:13:53” –stop-datetime=”2016-08-13 15:14:11” mysql-bin.000001 | mysql –uroot –p

错误日志

(1)主要用于记录Mysql服务的开启、关闭和错误信息,若服务启动不成功第一件事应该就是去看这个错误日志

(2)错误日志是默认开启的,且错误日志无法被关闭

(3)设置错误日志:在配置文件中,log-error=DIR/filename

# cat /etc/my.cnf |egrep "log-error"

log-error = /data/mysqldb/log/mysql-error.log

# ls /data/mysqldb/log

mysql-error.log

(4)删除错误日志

mysqladmin -u root -p flush-logs

# ls

mysql-error.log mysql-slow_query.log

通用查询日志

(1)用来记录用户的所有操作:启动和关闭mysql、更新语句、查询语句

(2)启用和设置通用查询日志:配置文件中,log=DIR/filename

(3)删除通用查询日志:

# mysqladmin -u root -p flush-logs

或# echo >access.log

慢查询日志

(1)记录执行时间超过指定时间的执行语句

(2)启动和设置慢查询日志:在配置文件中

log-slow-queries=DIR/filename

long_query_time=n//设置时间为n秒,默认为10s

(3)删除慢查询日志:

# mysqladmin -u root -p flush-logs

MySQL日志类型

a 错误日志(Error Log)

日志文件名称:用--log-error[=file_name]选项来指定mysql保存错误日志文件的位置,如果没有指定file_name,mysql使用默认的错误日志名host_name.err;

日志文件路径:默认情况下,日志文件都保存在mysql的数据目录中。如果执行FLUSH LOGS,错误日志用-old重新命名后缀,并且mysql创建一个新的空日志文件。(如果未给出-log-error选项,则不会重新命名)。

日志其他说明:如果不指定--log-error,或者(Windows)使用--console选项,错误被写入标准错误输出stderr。通常标准输出为终端。

b 查询日志(Query Log)

日志文件名称:(老版本方法)--log=[file_name]-l[file_name]选项进行启用。如果未指定file_name,默认名称为host_name.log

/etc/my.cnf[mysqld]下面添加log=/var/lib/mysql/Dragonwake.log重启后

#servicemysql restart

查看错误日志:

正确的配置方法,在/etc/my.cnf[mysqld]下面添加下如内容

# 查询日志

general_log=ON

general_log_file=/var/lib/mysql/Dragonwake.log

重启mysql

生成的查询日志文件Dragonwake.log

查询日志内容:

#tail -f /var/lib/mysql/Dragonwake.log

c 慢查询日志(Slow Query Log)

日志配置:--log-slow-queries[=file_name]选项启动时,mysql写一个包含了所有执行超过了long_query_time秒的SQL语句的日志。如果未指定file_name,默认为host_name-slow.err。如果给出了文件名,但不是绝对路径,文件则写入默认的数据目录。

/etc/my.cnf[mysqld]下面添加

# 执行超过1秒的sql会被log下来

long_query_time=1

# 将查询执行时间较慢的语句进行记录

log-slow-queries=/var/lib/mysql/Dragonwake-slow.log

重启mysql服务后,出现如下错误,

正确日志配置:mysql5.6版本以上,取消了参数log-slow-queries,更改为slow-query-log-file,同时必须设置slow_query_log=on

# 慢查询日志

# 执行超过1秒的sql会被log下来

long_query_time=1

# 开启慢查询

slow_query_log=on

# 慢查询日志路径

slow-query-log-file=/var/lib/mysql/Dragonwake-slow.log

重启MySQL

输出慢查询日志Dragonwake-slow.log

慢查询日志内容

d 更新日志(Update Log)

日志配置:用--log-update[=file_name]选项(不建议使用)

/etc/my.cnf[mysqld]下面添加,

# 更新查询

log-update=/var/lib/mysql/Dragonwake-update.log

出现如下错误:

暂未找到解决办法

e 二进制日志(Binary Log & Binary Log Index)

日志设置:用--log-bin[=file_name]选项

/etc/my.cnf[mysqld]下面添加,

# 二进制查询

log-bin=/var/lib/mysql/Dragonwake-bin.log

重启MySQL

输出二进制日志

查看二进制日志内容

#tail -f /var/lib/mysql/Dragonwake-bin.000001

f)mysql日志查询

mysql> show variables like'log_%';

h)mysql当前日志

mysql> show master status;

i)mysql二进制日志数目

mysql> show master logs;\

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022-05-13,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
Mysql日志解析
修改Mysql配置 Mysql配置地址为: C:\Program Files (x86)\MySQL\MySQL Server 5.5 如果无法修改可以把my.ini拷贝出来,修改完后,再拷贝回去! 如果配置了Mysql的日志生成路径,但是该目录尚未创建,那么启动会报错! 关于Mysql日志 splunk内置了两种mysql的日志,分别是mysqld以及mysql_error mysqld_error Standard mysql error log标准的mysql错误日志 050818 16:19:29
用户1154259
2018/01/17
5.2K0
MySQL日志管理
MySQL日志管理 错误日志 配置方法: vim /etc/my.cnf [mysqld] log-error=/tmp/mysql.log 查看配置方式: show variables like '%log%error%'; 作用: 记录mysql数据库的一般状态信息及报错信息,是我们对于数据库常规报错处理的常用日志。 一般查询日志 配置方法: vim /etc/my.cnf [mysqld] general_log=on general_log_file=/data/mysql/server2.log
863987322
2018/03/29
1.5K0
Mysql-14-mysql的日志管理
1.简介   日志文件记录着mysql数据库运行期间发生的变化,如:mysql数据库的客户端连接状况、sql语句的执行情况和错误信息等。当数据库遭到意外的损坏时,可以通过日志查看文件出错的原因,并且可以通过日志进行数据恢复;也可以通过日志文件分析数据、优化查询等。Mysql日志管理机制比较完善,它包含了以下几种常见的日志文件、分别为:错误日志(-log-err)、查询日志(-log)、二进制日志(-log-bin)、更新日志(-log-update)及慢查询日志(-log-slow-queries)。 2.
用户1173509
2018/01/17
1.1K0
Mysql-14-mysql的日志管理
《MySQL核心知识》第16章:日志
今天是《MySQL核心知识》专栏的第16章,今天为大家系统的讲讲MySQL中的日志,希望通过本章节的学习,小伙伴们能够举一反三,彻底掌握MySQL中日志相关的知识。好了,开始今天的正题吧。
冰河
2022/12/01
4210
《MySQL核心知识》第16章:日志
MySQL日志管理
一、日志类型: MySQL有几个不同的日志文件,可以帮助你找出mysqld内部发生的事情: 日志文件记入文件中的信息类型错误日志记录启动、运行或停止时出现的问题。查询日志记录建立的客户端连接和执行的语句。二进制日志记录所有更改数据的语句。主要用于复制和即时点恢复。慢日志记录所有执行时间超过long_query_time秒的所有查询或不使用索引的查询。事务日志记录InnoDB等支持事务的存储引擎执行事务时产生的日志。 默认情况下,所有日志创建于mysqld数据目录中。通过刷新日志,你可以强制 mysqld来
小小科
2018/05/04
1.8K0
MariaDB 备份与日志管理
数据备份是理员非常重要的工作之一,系统意外崩溃或者硬件的损坏都可能导致数据库的丢失,因此MariaDB管理员应该定期地备份数据库,使得在意外情况发生时,尽可能减少损失.
王 瑞
2022/12/28
7740
MySQL 之日志
MySQL日志记录了MySQL数据库日常操作和错误信息。MySQL有不同类型的日志文件(各自存储了不同类型的日志),从日志当中可以查询到MySQL数据库的运行情况、用户的操作、错误的信息等。
小手冰凉
2020/05/21
1.3K0
mysql日志记录
log-bin = /path/mysql-bin #其记录日志文件名为mysql-bin.index,mysql-bin.000001(注:重启或者单个文件超出限制会+1)
93年的老男孩
2019/12/18
5.3K0
MySQL安全----日志管理(一)
MySQL的日志有主要有四种,会记录不同的操作行为,分别是----二进制日志、错误日志、查询日志、慢查询日志。开启日志是MySQL安全的必要手段之一,但是会影响MySQL的性能,所以要学会日志管理,根据实际的业务需求来选择日志。
cultureSun
2023/05/18
6900
第八章· MySQL日志管理
作用: 记录mysql数据库的一般状态信息及报错信息,是我们对于数据库常规报错处理的常用日志。
DriverZeng
2022/09/26
7230
第八章· MySQL日志管理
MySQL Server 层四个日志
MySQL日志是在MySQL server上生成的,不管更改哪个存储引擎,这些日志都是需要有的,包括:
终有救赎
2023/11/09
2820
MySQL Server 层四个日志
MySQL(3)——日志
    由于数据库的读量大于写量,所以当读锁源源不断时,写锁就不能施加。所以可能采用读5个,写1个的策略施加锁就可以解决问题(具体的情况视各自的"锁策略"而定)
py3study
2020/01/09
5800
MySQL(3)——日志
MySQL日志介绍
(1) 错误日志log_error:记录MySQL服务的启动、运行或停止MySQL服务时出现的问题
AsiaYe
2019/11/06
1.3K0
MySQL日志介绍
后端开发必备的 MySQL 日志文件知识点
日志文件记录了影响MySQL数据库的各种类型活动,MySQL数据库中常见的日志文件有错误日志,二进制日志,慢查询日志和查询日志。下面分别对他们进行介绍。
挨踢小子部落阁
2019/09/27
6240
MySQL 日志
错误日志是 MySQL 中最重要的日志之一,它记录了当 mysqld 启动和停止时,以及服务器在运行过程中发生任何严重错误时的相关信息。当数据库出现任何故障导致无法正常使用时,建议首先查看此日志。
用户9615083
2022/12/25
1.6K0
MySQL的那些日志们
同大多数关系型数据库一样,日志文件是 MySQL 数据库的重要组成部分。MySQL 有几种不同的日志文件,通常包括错误日志文件,二进制日志,通用日志,慢查询日志,等等。这些日志可以帮助我们定位 mysqld 内部发生的事件,数据库性能故障,记录数据的变更历史,用户恢复数据库等等。本文主要描述错误日志文件。
程序员Leo
2023/08/07
2410
【MySQL高级】MySql中常用工具及Mysql 日志
此选项可以在Mysql客户端执行SQL语句,而不用连接到MySQL数据库再执行,对于一些批处理脚本,这种方式尤其方便。
陶然同学
2023/02/24
4180
【MySQL高级】MySql中常用工具及Mysql 日志
MySQL学习笔记(二)物理文件层的实现
在上一章我们了解到,物理文件层在MySQL架构位于最底层,将数据库的数据存储在文件系统上,并完成与存储引擎的交互。存储数据包括日志文件,数据文件,配置文件等。本章将介绍linux环境下MySQL的各类文件。
scarlett学习手册
2020/01/16
8450
mysql日志类型
  在MySQL中共有4中日志:错误日志、二进制日志、查询日志和慢查询日志 一、错误日志   错误日志名 host_name.err,并默认在参数DATADIR指定的目录中写入日志文件。可使用 --log-error[=file_name] 来指定位置。 二、二进制日志   记录了所有DDL语句和DML语句,但是不包括数据查询语句。语句以”事件“的形式保存。二进制日志名 host_name-bin.xxxxx,并默认在参数DATADIR指定的目录中。   需要定时清理日志文件,方法有:   (A) RESE
程序员同行者
2018/06/22
1.5K0
MySQL的存储引擎与日志说明
  类型:ext2 3 4 ,xfs 数据。 不管使用什么文件系统,数据内容不会变化,不同的是,存储空间、大小、速度。
惨绿少年
2019/05/24
1.2K0
相关推荐
Mysql日志解析
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档