需要开启binlog日志
编辑打开mysql配置文件my.ini,在[mysqld]区块设置/添加 log-bin=mysql-bin 然后重启mysql服务
查看二进制日志是否已开启
mysql> show variables like 'log_%';
log_bin的值为no表示已开启binlog日志
常用binlog日志操作命令
1.查看所有binlog日志列表
mysql> show master logs;
2.查看master状态,即最后(最新)一个binlog日志的编号名称,及其最后一个操作事件pos结束点(Position)值
mysql> show master status;
3.刷新log日志,自此刻开始产生一个新编号的binlog日志文件
mysql> flush logs;
注:每当mysqld服务重启时,会自动执行此命令,刷新binlog日志;在mysqldump备份数据时加 -F 选项也会刷新binlog日志;
4.重置(清空)所有binlog日志
mysql> reset master;
binlog恢复数据
.使用sql语句:show binlog events in 'mysql-bin.000001';查看binlog内容记录下开始位置(pos)和结束位置(end_log_pos)
进入C:\ProgramData\MySQL\MySQL Server5.7\Data(mysqlbinlog日志所在的目录)
用binlog命令备份到d盘
mysqlbinlog --start-position=1142--stop-position=1560 mysql-bin.000001 > d:\\test1.sql
--start-position=1142 起始pos点
--stop-position=1560 结束pos点
登录到mysql 命令:mysql -uroot –p
.然后执行:sourced://test1.sql (这里是用我们binlog备份的test1.sql去恢复数据)
binlog恢复数据库
.使用sql语句:show binlog events in 'mysql-bin.000001';查看binlog内容记录下开始位置(pos)和结束位置(end_log_pos)
进入C:\ProgramData\MySQL\MySQL Server5.7\Data
输入:mysqlbinlog mysql-bin.000001–-start-position=154 -–stop-position=1583 | mysql –uroot -p
如果只需要恢复一个数据库,必须要指定数据库,否则将对全服的数据库进行操作。
--database=zyyshop 指定只恢复zyyshop数据库(一台主机上往往有多个数据库,只限本地log日志)