redoundo锁-----------------------------------------日志管理log-error=/var/log/mysql.log二进制日志的“总闸”作用:1、是否开启2、二进制日志路径/data/mysql/3、二进制日志文件名前缀mysql-bin 4、文件名以"前缀".000001~Nlog-bin=/data/mysql/mysql-bin 二进制日志的“分开关”只有总闸开启才有意义,默认是开启状态。我们在有些时候会临时关闭掉。只影响当前会话。sql_log_bin=1/0二进制日志的格式statement,语句模式:记录信息简洁,记录的是SQL语句本身。但是在语句中出现函数操作的话,有可能记录的数据不准确。5.6中默认模式,但生产环境中慎用,建议改成row。row,行模式表中行数据的变化过程。记录数据详细,对IO性能要求比较高记录数据在任何情况下都是准确的。生产中一般是这种模式。5.7以后默认的模式。mixed,混合模式经过判断,选择row+statement混合的一种记录模式。一般不用。binlog的查看方式:1、查看binlog原始信息[root@db01 mysql-5.6.36]# mysqlbinlog mysql-bin.000001 /*!50530 SET @@SESSION.PSEUDO_SLAVE_MODE=1*/;mysqbin mysql-bin.000002 2、在row模式下,翻译成语句mysqlbinlog --base64-output='decode-rows' -v mysql-bin.000002 3、查看binlog事件show binary logs; 所有在使用的binlog信息show binlog events in ''4、如何截取binlog内容,按需求恢复(常规思路)(1)、show binary logs; show master status;(2)、show binlog events in '' 从后往前看,找到误操作的事务,判断事务开始position和结束position(3)、把误操作的剔除掉,留下正常操作到2个sql文件中(4)、先测试库恢复,把误操作的数据导出,然后生产恢复。遇到的问题:1、时间长2、对生产数据有一定影响,有可能会出现冗余数据3、有什么好的解决方案。1、flashback闪回功能(扩展)2、通过备份,延时从库--------------------------------SET GLOBAL expire_logs_days = 7;PURGE BINARY LOGS BEFORE now() - INTERVAL 3 day;PURGE BINARY LOGS TO 'mysql-bin.000010';reset master ------------------------慢日志 slow log调优过程中的工具日志。统计收集慢得语句------设定慢查询的阀值,超出次设定值的SQL即被记录到慢查询日志,缺省值为10s,现有版本可以指定零点几秒long_query_time 指定是否开启慢查询日志slow_query_log 指定慢日志文件存放位置,可以为空,系统会给一个缺省的文件host_name-slow.logslow_query_log_file 查询检查返回少于该参数指定行的SQL不被记录到慢查询日志min_examined_row_limit不使用索引的慢查询日志是否记录到索引log_queries_not_using_indexes慢日志扩展:Anemometer实现pt-query-digest 图形化https://www.cnblogs.com/xuanzhi201111/p/4128894.html