我的编程空间,编程开发者的网络收藏夹
学习永远不晚

MySQL之日志管理

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

MySQL之日志管理

MySQL之日志管理

日志

事务日志:transaction log

错误日志:error log

查询日志:query log

慢查询日志:slow query log

二进制日志:binary log

中继日志:reley log

命令日志:~/.mysql_history,记录各自终端输过的mysql命令

 

事务日志

事务日志:transaction log

事务型存储引擎自行管理和使用

redo log

undo log

Innodb事务日志相关配置:

show variables like '%innodb_log%';

innodb_log_file_size 5242880 每个日志文件大小(建议按生产情况调大,如1G,否则执行大的事务可能会直接提交,无法回滚)

innodb_log_files_in_group 2 日志组成员个数(建议按生产情况调多,如3个)

innodb_log_group_home_dir ./ 事务文件路径(建议事务日志跟数据存放在不同目录中)

中继日志:relay log

主从复制架构中,从服务器用于保存从主服务器的二进制日志中读取到的事件

optimize table tbl_name  整理表,例如进行大量修改|删除操作后,表文件大小并不会减小,执行此命令后可减小

 

错误日志

错误日志

mysqld启动和关闭过程中输出的事件信息

mysqld运行中产生的错误信息

event scheduler运行一个event时产生的日志信息

在主从复制架构中的从服务器上启动从服务器线程时产生的信息

错误日志相关配置

SHOW GLOBAL VARIABLES LIKE 'log_error'

错误文件路径:

log_error=/PATH/TO/LOG_ERROR_FILE

是否记录警告信息至错误日志文件

log_warnings=1|0 默认值1

 

通用日志

通用日志:记录查询操作

文件:file,默认值

表:table

通用日志相关设置

general_log=ON|OFF(通用日志,谁操作都记录,量会很大,不建议开启)

general_log_file=HOSTNAME.log

log_output=TABLE|FILE|NONE(日志记录在表里/文件里)

 

慢查询日志

慢查询日志:记录执行查询时长超出指定时长的操作

slow_query_log=ON|OFF 开启或关闭慢查询

long_query_time=N 慢查询的阀值,单位秒

slow_query_log_file=HOSTNAME-slow.log 慢查询日志文件

log_slow_filter = admin,filesort,filesort_on_disk,full_join,

full_scan,query_cache,query_cache_miss,tmp_table,tmp_table_on_disk

log_queries_not_using_indexes=ON 不使用索引也没有达到慢查询阀值的语句是否记录日志,默认OFF,即不记录(可以开启,看哪些命令记录得多了可以优化,例如加上索引)

log_slow_rate_limit = 1 多少次查询才记录,mariadb特有

log_slow_verbosity= Query_plan,explain 记录内容

log_slow_queries = OFF 同slow_query_log 新版已废弃

例:

select sleep(1),name from students; 每查一项休眠1秒

再show profile; 查看命令各阶段执行的时间,需先set profiling=1,

 

二进制日志

记录导致数据改变或潜在导致数据改变的SQL语句

记录已提交的日志

不依赖于存储引擎类型

功能:通过“重放”日志文件中的事件来生成数据副本

注意:建议二进制日志和数据文件分开存放

 

二进制日志记录格式

二进制日志记录三种格式

基于“语句”记录:statement,记录语句,默认模式

基于“行”记录:row,记录数据,日志量较大(生产中强烈建议基于“行”记录)

混合模式:mixed, 让系统自行判定该基于哪种方式进行

格式配置

show variables like '%binlog_format%';

 

二进制日志文件的构成

有两类文件

日志文件:mysql|mariadb-bin.文件名后缀,二进制格式

如: mysql-bin.000001

索引文件:mysql|mariadb-bin.index,文本格式

 

二进制日志相关的服务器变量:

sql_log_bin=ON|OFF:是否记录二进制日志,默认ON(此项可以动态更改,例如硬盘满了想临时不记录日志,可以临时关掉)

log_bin=/PATH/BIN_LOG_FILE:指定文件位置;默认OFF,表示不启用二进制日志功能,上述两项都开启才可(此项不支持动态更改,需写入配置文件中,需重启服务)

binlog_format=STATEMENT|ROW|MIXED:二进制日志记录的格式,默认STATEMENT(强烈建议改成ROW)

max_binlog_size=1073741824:单个二进制日志文件的最大体积,到达最大值会自动滚动,默认为1G

说明:文件达到上限时的大小未必为指定的精确值

sync_binlog=1|0:设定是否启动二进制日志即时同步磁盘功能,默认0,由操作系统负责同步日志到磁盘(即时的话效率低,好处是不会丢东西,一般情况0就行)

expire_logs_days=N:二进制日志可以自动删除的天数。 默认为0,即不自动删除(可留个30天)

 

二进制日志相关配置

查看mariadb自行管理使用中的二进制日志文件列表,及大小

SHOW {BINARY | MASTER} LOGS

查看使用中的二进制日志文件

SHOW MASTER STATUS

查看二进制文件中的指定内容

SHOW BINLOG EVENTS [IN 'log_name'] [FROM pos] [LIMIT [offset,] row_count]

show binlog events in ‘mysql-bin.000001' from 6516 limit 2,3

 

mysqlbinlog

mysqlbinlog:二进制日志的客户端命令工具

命令格式:

mysqlbinlog [OPTIONS] log_file…

--start-position=# 指定开始位置

--stop-position=#

--start-datetime=

--stop-datetime=

时间格式:YYYY-MM-DD hh:mm:ss

--base64-output[=name]

示例:

mysqlbinlog --start-position=6787 --stop-position=7527 /var/lib/mysql/mariadb-bin.000003

mysqlbinlog --start-datetime="2018-01-30 20:30:10" --stop-datetime="2018-01-30 20:35:22" mariadb-bin.000003;

 

二进制日志事件的格式:

# at 328

#151105 16:31:40 server id 1 end_log_pos 431 Query thread_id=1 exec_time=0 error_code=0

use `mydb`;

SET TIMESTAMP=1446712300;

CREATE TABLE tb1 (id int, name char(30))

;

事件发生的日期和时间:151105 16:31:40

事件发生的服务器标识:server id 1

事件的结束位置:end_log_pos 431

事件的类型:Query

事件发生时所在服务器执行此事件的线程的ID:thread_id=1

语句的时间戳与将其写入二进制文件中的时间差:exec_time=0

错误代码:error_code=0

事件内容:

GTID:Global Transaction ID,mysql5.6以mariadb10以上版本专属属性:GTID

 

清除指定二进制日志:

PURGE { BINARY | MASTER } LOGS

{ TO 'log_name' | BEFORE datetime_expr }

示例:

PURGE BINARY LOGS TO ‘mariadb-bin.000003’;删除3前日志

PURGE BINARY LOGS BEFORE '2017-01-23';

PURGE BINARY LOGS BEFORE '2017-03-22 09:25:30';

 

删除所有二进制日志,index文件重新记数

RESET MASTER [TO #]; 日志文件从#开始记数,默认从1开始,一般是master第一次启动时执行,MariaDB10.1.6开始支持TO #

 

切换二进制日志文件:

FLUSH LOGS;


免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

MySQL之日志管理

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

数据库学习之十:mysql日志管理

十、mysql日志管理课程大纲1、MySQL日志类型简介2、MySQL错误日志配置及查看3、MySQL binlog介绍及管理实战4、MySQL 慢查询日志设置及管理实战1、日志的类型简介mysql> show variables like "%log_err
数据库学习之十:mysql日志管理
2014-12-31

MySQL事务日志管理

MySQL事务日志管理是数据库管理系统中的一项重要任务,它涉及到数据的完整性、可靠性和安全性。事务日志记录了数据库的所有更改,包括插入、更新、删除等操作,以便在发生故障时能够恢复数据。以下是关于MySQL事务日志管理的一些关键概念和操作:二
MySQL事务日志管理
2024-10-20

Java日志管理组件之——MDC

目录 一、 前言二、作用三、基本使用步骤四、常见使用场景 一、 前言 当我们在开发大型分布式系统时,日志记录是一个非常重要的方面,因为它可以帮助我们了解系统的行为和性能,并且可以用于排查问题。在一个分布式系统中,一个请求可能会经
2023-08-18

MySQL日志管理在Linux系统

MySQL日志是MySQL数据库中记录运行过程中发生的事件的文件。MySQL日志包括错误日志、慢查询日志、二进制日志和查询日志。在Linux系统中,可以通过以下步骤管理MySQL日志:错误日志:MySQL错误日志记录了MySQL服务器运行过
MySQL日志管理在Linux系统
2024-08-16

MySQL数据库审计日志管理

MySQL数据库审计日志管理是确保数据库安全性和可追溯性的重要环节。通过记录和分析数据库的访问和操作行为,审计日志可以帮助管理员发现潜在的安全威胁、分析性能瓶颈以及追踪潜在的数据篡改或误操作。以下是关于MySQL数据库审计日志管理的一些关键
MySQL数据库审计日志管理
2024-10-20

Linux MySQL的二进制日志管理

MySQL的二进制日志(Binary Log)是一种记录数据库更改的日志文件,可以用于数据恢复、复制和故障恢复等操作。在Linux系统中,管理MySQL的二进制日志可以通过以下几种方式进行:配置MySQL的二进制日志参数:在MySQL配置文
Linux MySQL的二进制日志管理
2024-08-16

MySQL INSERT锁与数据库日志管理

MySQL中的INSERT锁是一种表级别的锁,它在插入数据时会对整个表进行加锁,防止其他会话对表进行写操作。这种锁在插入大量数据时非常有效,可以防止其他会话对同一表进行写操作,从而保证数据的一致性。数据库日志管理是指MySQL中对数据库操
MySQL INSERT锁与数据库日志管理
2024-08-19

MySQL日志管理和备份与恢复

目录一.mysql 日志管理1、错误日志2、通用查询日志3、二进制日志4、慢查询日志5、查看日志6、实例操作二、数据库备份的重要性与分类1、数据备份的重要性2、从物理与逻辑的角度,备份分为:3、从数据库的备份策略角度,备份可分为:三、常见的
2023-04-03

编程热搜

目录