MySQL Binary Log也就是常说的bin-log, ,是mysql执行改动产生的二进制日志文件,其主要作用有两个:
* 数据回复
* 主从数据库。用于slave端执行增删改,保持与master同步。
1.开启binary log功能
需要修改mysql的配置文件,本篇的实验环境是win7,配置文件为mysql安装目录/MySQL Server 5.1下的my.ini,添加一句log_bin = mysql_bin即可
eg: [mysqld] ...... log_bin = mysql_bin ...... log_bin是生成的bin-log的文件名,后缀则是6位数字的编码,从000001开始,按照上面的配置,生成的文件则为: mysql_bin.000001 mysql_bin.000002 ...... |
配置保存以后重启mysql的服务器,用show variables like '%bin%'查看bin-log是否开启,如图:
2.查看产生的binary log
bin-log因为是二进制文件,不能通过记事本等编辑器直接打开查看,mysql提供两种方式查看方式,在介绍之前,我们先对数据库进行一下增删改的操作,否则log里边数据有点空。
create table bin( id int(10) primary key auto_increment,name varchar(255)); |
(测试前我已经建表)
insert into bin(name) values ('orange'); |
1.在客户端中使用 show binlog events in 'mysql_bin.000001' 语句进行查看,为了排序美观,可以在结尾加/G使结果横变纵,此时结尾无需加;语句结束符。
eg:
mysql> show binlog events in 'mysql_bin.000001'/G ...............省略............... *************************** 3. row *************************** Log_name: mysql_bin.000001 Pos: 174 Event_type: Intvar Server_id: 1 End_log_pos: 202 Info: INSERT_ID=2 *************************** 4. row *************************** Log_name: mysql_bin.000001 Pos: 202 Event_type: Query Server_id: 1 End_log_pos: 304 Info: use `test`; insert into bin(name) values ('orange') *************************** 5. row *************************** ...............省略............... |
2.用mysql自带的工具mysqlbinlog,这是我们就需要知道bin-log存在硬盘的什么位置,win7默认存在C:/ProgramData/MySQL/MySQL Server 5.1/data文件夹下面,如果没有此文件夹,那我们可以通过配置文件中的 datadir="C:/ProgramData/MySQL/MySQL Server 5.1/Data/" 定位,如果还没有,那我就会说“各个系统的搜索功能都做的不错!”。这种查看方式就没那个美观了,如下
新闻热点
疑难解答