Mysql配置文件 binlog和慢日志
binlog
binlog_format
binlog日志格式,mysql默认采用statement,建议使用mixed
STATEMENT模式(SBR)
每一条会修改数据的sql语句会记录到binlog中。优点是并不需要记录每一条sql语句和每一行的数据变化,减少了binlog日志量,节约IO,提高性能。缺点是在某些情况下会导致master-slave中的数据不一致(如sleep()函数, last_insert_id(),以及user-defined functions(udf)等会出现问题)
ROW模式(RBR)
不记录每条sql语句的上下文信息,仅需记录哪条数据被修改了,修改成什么样了。而且不会出现某些特定情况下的存储过程、或function、或trigger的调用和触发无法被正确复制的问题。缺点是会产生大量的日志,尤其是alter table的时候会让日志暴涨。
MIXED模式(MBR)
以上两种模式的混合使用,一般的复制使用STATEMENT模式保存binlog,对于STATEMENT模式无法复制的操作使用ROW模式保存binlog,MySQL会根据执行的SQL语句选择日志保存方式。
查询:
在线配置:
配置文件:binlog_format = MIXED
log_slave_updates
把relay-log里的日志内容再记录到slave本地的binlog里,默认关闭,主主就要开启。
如果关闭当主主复制的时候会报错,导致主B写入数据时主A无法同步,5.7版本及以后不用开启,用一张gtid_executed系统表记录同步复制的信息(UUID:事务号),减轻了压力。
查询:show variables like 'log_slave_updates';
在线配置:
配置文件:log_slave_updates = 0
log-bin|log-bin-index
log-bin将开启binlog日志,mysql-bin 是日志的基本名或前缀名,可以更换。
log-bin-index指定的是binlog文件的索引文件,这个文件管理了所有的binlog文件的目录,不用进行更改,默认即可。
查询:
在线配置:
配置文件:log-bin=mysql-bin | log-bin-index=mysql-bin.index
expire_logs_days
超过指定天数的binlog将被删除
查询:
在线配置:
配置文件:expire_logs_days = 7
relay-log|relay-log-index
relay-log在从上指定从主那里同步过来的binlog文件存放位置。
relay-log-index定义relay-log-index的文件名,类似binlog的log-bin-index。
查询:show variables like '%relay%';
在线配置:
配置文件:relay-log=mysql.relay-log | relay-log-index=mysql.relay-log.index
relay-log-info-file
设置relay-log.info的位置和名称(relay-log.info记录MASTER的binary_log的恢复位置和relay_log的位置)
查询:show variables like '%relay%';
在线配置:
配置文件:relay-log=mysql.relay-log | relay-log-index=mysql.relay-log.index
max_relay_log_size
从服务器在主服务器上复制的binlog日志,如果超过这个值,将形成一个新的日志。用于控制文件大小。
查询:
在线配置:
配置文件:max_relay_log_size = 512M
binlog-ignore-db|replicate-ignore-db
binlog-ignore-db无需开启二进制日志文件的数据库,多个数据库则要重复设置
replicate-ignore-db来设置不需要同步的库
bin-do-db,bin-ignore-db 为互斥关系,只需设置其中一项即可
查询:
在线配置:
配置文件:
binlog-ignore-db = mysql
binlog-ignore-db = test
binlog-ignore-db = information_schema
binlog-ignore-db = performance_schema
|
replicate-ignore-db = mysql
replicate-ignore-db = test
replicate-ignore-db = information_schema
replicate-ignore-db = performance_schema
binlog_cache_size
二进制日志缓冲区吗,默认是32k。该参数是基于会话的,不要设置过大。
当事务的记录大于设定的binlog_cache_size时,mysql会把缓冲区中的日志信息写入一个临时文件中,所以该值也不能设置过小。
使用命令show global status like 'binlog_cache_%';查看Binlog_cache_disk_use(记录了使用临时文件写二进制日志的次数)和Binlog_cache_use(用缓冲的次数),可以看到binlog_cache_size值设置小了。
+-----------------------+-------+
| Variable_name | Value |
+-----------------------+-------+
| Binlog_cache_disk_use | 1008 |
| Binlog_cache_use | 5721 |
+-----------------------+-------+
查询:show variables like 'binlog_cache_size';
在线配置:
配置文件:binlog_cache_size = 64M
max_binlog_size
超过这个数值,将会把日志写到一个新的文件中。最大值1GB,最小值1M,默认1GB。
查询:
在线配置:
配置文件:max_binlog_size = 512M
max_binlog_cache_size
表示的是binlog 能够使用的最大cache 内存大小,默认是1M。
查询:show global status like 'bin%';
在线配置:set global max_binlog_cache_size=1048576*100
配置文件:max_binlog_cache_size = 100M
慢查询
slow-query-log
是否开启慢查询日志,默认OFF关闭。
查询:show variables like '%slow%';
在线配置:set global slow_query_log=1;
配置文件:slow_query_log=1
long_query_time
指定多少秒返回查询的结果为慢查询,单位秒。默认为10秒,正好等于数值的也不会记录,要超过。
查询:show global status like 'bin%';
在线配置:set global long_query_time=2;
配置文件:long_query_time=2
slow_query_log_file
指定保存路径及文件名,默认为数据文件目录,hostname-slow.log
查询:show variables like "slow%";
在线配置:
配置文件:slow_query_log_file=/data/hostname-slow.log
log-queries-not-using-indexes
记录所有没有使用到索引的查询语句,但可能会导致日志激增。
查询:
在线配置:
配置文件:log-queries-not-using-indexes = TRUE
log_throttle_queries_not_using_indexes
表示每分钟允许记录到slow log的且未使用索引的sql语句次数,配合log-queries-not-using-indexes使用。限制条目数后,日志将不会激增。
查询:
在线配置:
配置文件:log_throttle_queries_not_using_indexes=1000
min_examined_row_limit
记录那些由于查找了多余1000次而引发的慢查询
查询:
在线配置:
配置文件:min_examined_row_limit=1000
log_slow_admin_statements
记录optimize table,analyze table和alter table等语句引发的慢查询
查询:
在线配置:
配置文件:log-slow-admin-statements = TRUE
log-slow-admin-statements
记录从服务器产生的慢查询
查询:
在线配置:
配置文件:log-slow-admin-statements = TRUE
log_slow_filter
慢查询日志过滤类型
查询:
在线配置:
配置文件:log_slow_filter = full_scan,full_join,tmp_table,tmp_table_on_disk,filesort,filesort_on_disk
log_slow_verbosity
是否记录详细格式的日志信息
查询:
在线配置:
配置文件:log_slow_verbosity = full
Mysql配置文件 binlog和慢日志的更多相关文章
- mysql之binlog和各类日志介绍
1.错误日志 错误日志作用: 记录MySQL的启动.停止信息以及在MySQL运行过程中的错误信息. 参数log_error(默认开启) 修改后重启生效 log_error=[path/[file_n ...
- mysql 通过binlog 查看执行日志
环境:linux deepin15.7 mysql 5.7 1.开启binlog vim /etc/mysql/mysql.conf.d/mysqld.cnf 添加 log_bin = /var/ ...
- 解说mysql之binlog日志以及利用binlog日志恢复数据
众所周知,binlog日志对于mysql数据库来说是十分重要的.在数据丢失的紧急情况下,我们往往会想到用binlog日志功能进行数据恢复(定时全备份+binlog日志恢复增量数据部分),化险为夷! 废 ...
- Mysql之binlog日志说明及利用binlog日志恢复数据操作记录
众所周知,binlog日志对于mysql数据库来说是十分重要的.在数据丢失的紧急情况下,我们往往会想到用binlog日志功能进行数据恢复(定时全备份+binlog日志恢复增量数据部分),化险为夷! 一 ...
- MySQL的binlog日志<转>
binlog 基本认识 MySQL的二进制日志可以说是MySQL最重要的日志了,它记录了所有的DDL和DML(除了数据查询语句)语句,以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二进制日 ...
- Mysql利用binlog日志恢复数据操作(转)
a.开启binlog日志:1)编辑打开mysql配置文件/etc/mys.cnf[root@vm-002 ~]# vim /etc/my.cnf在[mysqld] 区块添加 log-bin=mysql ...
- MySQL的binlog日志恢复(转)
binlog 基本认识 MySQL的二进制日志可以说是MySQL最重要的日志了,它记录了所有的DDL和DML(除了数据查询语句)语句,以事件形式记录,还包含语句所执行的消耗的时间,MySQL的二进制日 ...
- 【转】Mysql之binlog日志说明及利用binlog日志恢复数据操作记录
众所周知,binlog日志对于mysql数据库来说是十分重要的.在数据丢失的紧急情况下,我们往往会想到用binlog日志功能进行数据恢复(定时全备份+binlog日志恢复增量数据部分),化险为夷! 废 ...
- 20180530利用Maxwell组件实时监听Mysql的binlog日志
转自:https://blog.csdn.net/qq_30921461/article/details/78320750 http://kafka.apache.org/quickstart htt ...
随机推荐
- 大爽Python入门教程 3-4 实践例题
大爽Python入门公开课教案 点击查看教程总目录 1. 求和 使用循环,计算列表所有项的和,并输出这个和. 列表示例 lst = [8, 5, 7, 12, 19, 21, 10, 3, 2, 11 ...
- ubuntu 首次登陆设置root密码
用过ubuntu的人都知道,ubuntu默认root密码是随机的,即每次开机都有一个新的root密码.我们可以在终端输入命令sudo passwd,然后输入当前用户的密码 给root用户设置密码 ...
- Redis | 第一部分:数据结构与对象 上篇《Redis设计与实现》
目录 前言 1. 简单动态字符串 1.1 SDS的定义 1.2 空间预分配与惰性空间释放 1.3 SDS的API 2. 链表 2.1 链表与节点的定义 2.2 链表的API 3. 字典 3.1 哈希表 ...
- 力扣 - 剑指 Offer 52. 两个链表的第一个公共节点
题目 剑指 Offer 52. 两个链表的第一个公共节点 思路1(栈) 若两个链表相遇,则从它开始相遇的地方到链表末尾应该都是相同的,那么我们可以将两个链表分别放入两个栈中,然后依次循环比较两个栈顶的 ...
- Node.js实现前后端交换——用户登陆
最近学习了一点Node.js的后端知识,于是作为一个学习前端方向的我开始了解后端,话不多说,开始介绍.首先,如果你想要更好的理解这篇博客,你需要具备html,css,javascript和Node.j ...
- 初识XSS攻击
初识XSS攻击 本文参考于<白帽子讲Web安全>第3章跨站脚本攻击(XSS),该书出版于2014年,因而现在可能存在一些新场景或新技术而未被提及,但本文对学习和了解XSS攻击仍具有重要价值 ...
- 洛谷 P3215 [HNOI2011]括号修复 / [JSOI2011]括号序列(fhq-treap)
题目链接 题意:有一个长度为 \(n\) 的括号序列,你需要支持以下操作: 将 \([l,r]\) 中所有括号变为 \(c\) 将 \([l,r]\) 区间翻转 将 \([l,r]\) 区间中左括号变 ...
- Codeforces 436D - Pudding Monsters(dp)
Codeforces 题目传送门 & 洛谷题目传送门 u1s1 这题数据范围有点迷惑啊--乍一看 \(\mathcal O(nm)\) 过不去,还以为是正解是 \(\mathcal O(n+m ...
- Codeforces 1413F - Roads and Ramen(树的直径+找性质)
Codeforces 题目传送门 & 洛谷题目传送门 其实是一道还算一般的题罢--大概是最近刷长链剖分,被某道长链剖分与直径结合的题爆踩之后就点开了这题. 本题的难点就在于看出一个性质:最长路 ...
- 金蝶EAS——登录某个数据中心门户时报错“获取用户相关信息失败!请查看服务器日志,并确认是否数据库设置错误或者版本不匹配!”
登录服务器后台,查看金蝶BOS控制台,选择数据中心中的目标数据中心,点击测试连接,提示报错如下: 说明是数据库问题,需要登录数据库服务器去检查数据库.详细操作见: