binlog开启和查看
1. 首先需要将mysql的binlog日志打开。默认是关闭的。
参考网址:Windows下Mysql5.7开启binlog步骤及注意事项(https://www.cnblogs.com/wangwust/p/6433453.html)
参考网址:https://blog.csdn.net/zjerryj/article/details/77152226
参考网址:mysql row日志格式下 查看binlog sql语句
参考网址:GTID binlog解析后导入无效
使用mysql Command Line Clinet。
查看是否已开启binlog日志输出。
--》 show binary logs; ERROR 1381 (HY000): You are not using binary logging (表示未开启)
※注意: my.ini 存放在 C:\ProgramData\MySQL\MySQL Server 5.7 而非 Program文件目录下,注意ProgramData文件夹默认是隐藏不显示。
Windows下MySQL的配置文件是my.ini 在主目录下
Linux下是/etc/my.conf
用管理员身份打开my.ini,添加binlog输出
- # binlog node
- log_bin = mysql-bin
- binlog_format = ROW
server_id=1
注意有可能server_id已经存在,这个ID要唯一,不能和别的slave_id重复。
#修改UTF8
default-character-set=UTF8
character-set-server=UTF8
※ 注意不是UTF-8
由于binlog日志不会自动清除,因此需要手动设置过期删除,防止文件过大占用内存。
- expire-logs-days=
重启mysql57服务。
mysql服务添加到path中则直接在控制台:
--》C:\WINDOWS\system32>net stop mysql57
--》C:\WINDOWS\system32>net start mysql57
此时在mysql Command Line Client:
--> show binary logs; 可查看binlog日志
--> show variables like '%log_bin%'; 这个亦可说明log是否有开启
--> set global expire_logs_days=30; //防止binlog积压,占用内存,设置失效30天
--> show variables like '%expire_logs_days%'; //查看
生成的binlog日志默认就在log_bin 给的文件位置下,如果没有路径就是my.ini对应的data文件夹下。
- log_bin = D:\log\mysql\mysql-bin
※注意:对应的文件夹要存在,否则无法启动。
- mysql-bin.
- mysql-bin.index
查看:
--》show binlog events; //获取第一个binlog的日志
--》 show binlog events in 'mysql-bin.000002'; //获取指定的binlog日志
--》 show master status\G; //查看当前正在写入的binlog日志
--》 show binlog events from 219; //根据pos获取日志
在cmd下使用mysqlbinlog转化binlog二进制日志还原为sql:
-》mysqlbinlog -d [schemal] --start-datetime="2018-10-15 8:10:01" --stop-datetime="2018-10-15 18:10:00" d:\log\mysql\mysql-bin.000001 > d:\log\insert.sql
这样就可以还原之前被处理掉的数据。
如果查看到的sql文件中并不能直接看到insert或update,delete语句,而有base64加码的数据,则需要在导出sql时做转化。
-》 mysqlbinlog --base64-output=decode-rows -v -d [schemal] --start-datetime="2018-10-15 8:10:01" --stop-datetime="2018-10-15 18:10:00" d:\log\mysql\mysql-bin.000002 > d:\log\insert2.sql
也可以使用position代替date。
--start-position
--stop-position
可以直接执行binlog进行还原:
--》mysqlbinlog -d [schema] --start-datetime="2018-10-15 8:10:01" --stop-datetime="2018-10-15 18:10:00" d:\log\mysql\mysql-bin.000004 |mysql -u root -p
我们可以直接将还原的sql直接执行。
--》mysql source D:\log\insert4.sql
※ 执行后发现数据并未同步到数据库中,提示信息正常。
打开 insert4.sql发现里面有好多SET @@SESSION.GTID_NEXT= [序列码]
此内容为事务控制用的信息,但这些信息已经被用过了,被记入到Executed_Gtid_Set中,因此执行被跳过。
在导出sql的语句中添加 --skip-gtids=true
binlog开启和查看的更多相关文章
- Window 下mysql binlog开启及查看,mysqlbinlog
查看是否开启了binlog: win+r => cmd => 连接mysql=>show variables like 'log_%'; mysql> show variabl ...
- binlog之三:binlog开启、查看
0.开启二进制日志记录功能: #vim /etc/my.cnf [mysqld] log_bin=mysql-bin b ...
- mysql日志开启和查看
mysql日志开启和查看. 找到mysql根目录下的my.ini文件,打开在下面插入 log-bin=mysql-bin binlog_format=mixed 然后重启mysql. 在dos端登录m ...
- MySQL 开启和查看bin-log日志
1.5.7版本前修改my.cnf文件,添加log-bin=my-bin(my.cnf的位置根据自己安装的路径查看)# vi /usr/local/mysql/my.cnflog-bin=my-bin ...
- 开启和查看mysql的bin-log日志
[root@VM_0_7_centos data]# vim /etc/my.cnf [root@VM_0_7_centos data]# vim /etc/my.cnf [root@VM_0_7_c ...
- mysql中如何开启binlog?开启二进制日志文件?binary log?
需求描述: 开启mysql的binlog即binary log日志功能,在此记录下. 版本描述: mysql版本:5.7.21-log 操作过程: 1.修改my.cnf并且将以下参数加入其中,重启my ...
- Apache开启状态查看页面(原创贴-转载请注明出处)
=================写在前面的话================== 场景描述:有时候我们需要查看apache的运行状态,只需要开启apache的status功能就可以实现,但是stat ...
- MySQL的binlog数据如何查看
binlog介绍 binlog,即二进制日志,它记录了数据库上的所有改变. 改变数据库的SQL语句执行结束时,将在binlog的末尾写入一条记录,同时通知语句解析器,语句执行完毕. binlog格式 ...
- linux查看端口是否已开启和查看文件数
查看端口是否开启 lsof -i:80 查看文件数 ls | wc -w
随机推荐
- Python类方法、静态方法与实例方法 -----类里面不需要实例化参数 和没带self的函数 调用此函数的方法
来源: https://www.cnblogs.com/blackmatrix/p/5606364.html 静态方法是指类中无需实例参与即可调用的方法(不需要self参数),在调用过程中,无需将类实 ...
- Heap堆分析(堆转储、堆分析)
一.堆直方图 减少内存使用时一个重要目标,在堆分析上最简单的方法是利用堆直方图.通过堆直方图我们可以快速看到应用内的对象数目,同时不需要进行完整的堆转储(因为堆转储需要一段时间来分析,而且会消耗大量磁 ...
- Java-Runoob-高级教程-实例-方法:15. Java 实例 – 重载(overloading)方法中使用 Varargs
ylbtech-Java-Runoob-高级教程-实例-方法:15. Java 实例 – 重载(overloading)方法中使用 Varargs 1.返回顶部 1. Java 实例 - 重载(ove ...
- JS的正则表达式简介
1.JS的正则表达式 1.1 简介 JS的正则表达式比较简单,总体上只分为两个功能:一个是test——用于匹配字符串是否符合规定的正则表达式规则:另外一个是exec——用于获取匹配到的数据. 1.2 ...
- VI使用手册(常见命令)
VI使用手册 模式切换 i键开始进入编辑模式,Esc进入一般模式,保存退出:wq,不保存退出q,强制退出q! 如何定位到行文档首位,行首位? gg或者1G命令将光标移动到文档开头G命令将光标移动到文档 ...
- tf.nn.embedding_lookup
tf.nn.embedding_lookup(params, ids, partition_strategy=’mod’, name=None, validate_indices=True, max_ ...
- sql语句中order by 多个字段同时排序的应用
order by 后面可以跟多个字段进行排序 用A1代表第一个字段,A2代表第二个字段 一.order by A1 , A2 desc 指的是用A1升序A2降序 二.order by A1 a ...
- Win7 发生验证错误 要求的函数不受支持
今天登陆服务器突然登不上了,给我报了一个错误“发生验证错误 要求的函数不受支持”,用同事的win7电脑和win10电脑都可以,就是我的不行,气死我了,然后我百度百度啊,用了好几种“说用了就OK”的办法 ...
- Solr——Windows下部署Solr7.5.0至jetty、Tomcat
Solr6用默认的Jetty启动 需要的软件支持 JDK1.8以上 Solr6的安装包(solr-7.5.0.zip ) Solr自带一个Jetty环境,可以很方便的运行Solr. 直接到解压缩的so ...
- Noi.ac #309. Mas的童年(贪心)
/* 用所谓的加法拆分操作得到 x + y = (x ^ y) + 2 * (x & y) 那么我们这两段异或相当于前缀和 + 2 * 分段使左右两块&最大 记当前前缀异或和为S, 那 ...