binlog 就是binary log,二进制日志文件,这个文件记录了mysql全部的增、删、改语句。经过binlog日志咱们能够作数据恢复,作主从复制等等。能够看到,只要有了这个binlog,咱们就拥有了mysql的完整备份了。mysql
咱们时常会碰到这样的需求,就是要监听某个表的变化,而后来作一些操做。sql
若是该表数据只增长、不删除修改的话,要监听比较简单,能够定时去查询最新的id便可。但要有删除、修改操做的话,免不了就得全表扫描,效率极低。假若该表发生变化时,能触发个事件之类的可供监听,那最好不过。工具
如今咱们就能够经过binlog来完成了。监听binlog的变化便可,这样每次执行了什么语句都会提如今binlog里,咱们就能监听到了。.net
binlog默认是关闭的,咱们要开启它,就须要来修改mysql的配置文件。rest
mac上brew安装的mysql,默认安装后的目录是/usr/local/Cellar,版本是5.7.21。日志
能够看到,目录下没有配置文件,这和其余的一些版本可能不同,别的版本在根目录下会有个my.ini,或者my.cnf文件,或者在support-files里有个my-default.cnf文件,这个版本是没有的。orm
要修改配置文件,就须要咱们本身来建立。server
在/etc/目录下建立一个my.cnf文件,内容是blog
[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%' ;
上面箭头是没有设置my.cnf时的,下面是设置完my.cnf并重启后的。
能够经过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。