mysqlbinlog监听_1监听mysql表内容变化,mysql开启binlog binlog 就是binary log,⼆进制⽇志⽂件,这个⽂件记录了mysql所有的增、删、改语句。通过binlog⽇志我们可以做数据恢复,做主从复制等等。可以看到,只要有了这个binlog,我们就拥有了mysql的完整备份了。
我们时常会碰到这样的需求,就是要监听某个表的变化,然后来做⼀些操作。
如果该表数据只增加、不删除修改的话,要监听⽐较简单,可以定时去查询最新的id即可。但要有删除、修改操作的话,免不了就得全表扫描,效率极低。倘若该表发⽣变化时,能触发个事件之类的可供监听,那最好不过。
现在我们就可以通过binlog来完成了。监听binlog的变化即可,这样每次执⾏了什么语句都会提现在binlog⾥,我们就能监听到了。
binlog默认是关闭的,我们要开启它,就需要来修改mysql的配置⽂件。
mac上brew安装的mysql,默认安装后的⽬录是/usr/local/Cellar,版本是5.7.21。
可以看到,⽬录下没有配置⽂件,这和其他的⼀些版本可能不⼀样,别的版本在根⽬录下会有个my.ini,或者myf⽂件,或者在
support-files⾥有个my-defaultf⽂件,这个版本是没有的。
要修改配置⽂件,就需要我们⾃⼰来创建。
在/etc/⽬录下创建⼀个myf⽂件,内容是
[mysqld]
server_id = 1
log-bin = mysql-bin
binlog-format = ROW
mysql-bin只是个名字⽽已,可以随便起。将来保存的⽇志⽂件名就是mysql-bin.000001,mysql-bin.000002这样的。
注意 binlog_format 必须设置为 ROW, 因为在 STATEMENT 或 MIXED 模式下, Binlog 只会记录和传输 SQL 语句(以减少⽇志⼤⼩),⽽不包含具体数据,我们也就⽆法保存了。
然后通过brew restart mysql重启mysql。再通过mysql -uroot -p命令进⼊mysql控制台,执⾏
show variables like '%log_bin%' ;
上⾯箭头是没有设置myf时的,下⾯是设置完myf并重启后的。
可以通过show master status命令查看当前正在写⼊的binlog⽇志状态。
还有如下命令:
刷新binlog⽇志⽂件  flush logs #刷新之后会新建⼀个新的binlog⽇志。
清空⽇志⽂件 reset master。
查看第⼀个binlog⽂件的内容 show binlog events。
查看指定binlog⽂件的内容 show binlog events in 'mysql-bin.000004'。
获取binlog⽂件列表 show binary logs。
只有了binlog,那还是不够的,我们还需要⼀个监听binlog的⼯具。下⼀篇来看canal
---------------------
作者:天涯泪⼩武
来源:CSDN
mysql下载下来是一个文件夹版权声明:本⽂为博主原创⽂章,转载请附上博⽂链接!

版权声明:本站内容均来自互联网,仅供演示用,请勿用于商业和其他非法用途。如果侵犯了您的权益请与我们联系QQ:729038198,我们将在24小时内删除。