重庆分公司,新征程启航
为企业提供网站建设、域名注册、服务器等服务
二进制日志由包含“ 事件 ”的文件组成,这些 事件描述了对数据库内容的修改。服务器以二进制格式写入这些文件。
1.查看binlog文件名列表
show binary logs;
10年积累的成都网站制作、成都网站建设经验,可以快速应对客户对网站的新想法和需求。提供各种问题对应的解决方案。让选择我们的客户得到更好、更有力的网络服务。我虽然不认识你,你也不认识我。但先网站设计后付款的网站建设流程,更有温岭免费网站建设让你可以放心的选择与我们合作。
2.查看binlog文件内容
show binlog events in 'MySQL-bin.000001' limit 10;
3.查看binlog当前位置点
show master status;
4.查看binlog 格式
日志格式:statement,row,
row:优点:日志比较清楚,会记录每行数据修改细节 缺点:会产生大量的日志
statement:优点:只记录sql语句,解决了row格式的缺点,减少了日志量,节省I/O 及存储资源,提高了性能。 缺点:有些sql语句不能复制到slava,导致主从不一致,存在一些bug,语句执行错误不易恢复。
mixed:处于row与statement格式之间,很好的处理了其优缺点。
SELECT @@binlog_format;
5.刷新日志
flush logs;
6.清除日志
reset master;
7.用mysqlbinlog工具查看
mysqlbinlog -v --base64-output=decode-rows /usr/app/mysqllog/mysql_bin.000001
基于开始/结束时间
mysqlbinlog --start-datetime='2018-12-13 00:00:00' --stop-datetime='2018-12-14 15:01:01' -d hadoop /usr/app/mysqllog/mysql-bin.000001
基于pos值输出到压缩文件 ,注:test是库名,/var/lib/mysql/mysql-bin.000001是二进制文件路径
mysqlbinlog --start-position=2098 --stop-position=2205 -d test /usr/app/mysqllog/mysql-bin.000001 |gzip >test.sql.gz
提取指定位置的多个binlog日志文件
mysqlbinlog --start-position="120" --stop-position="332" /usr/app/mysqllog/mysql-bin.000001 /usr/app/mysqllog/mysql-bin.000002|more
提取指定数据库binlog并转换字符集到UTF8
mysqlbinlog --database=test --set-charset=utf8 /usr/app/mysqllog/mysql-bin.000001 /usr/app/mysqllog/mysql-bin.000002 >test.sql
恢复数据
mysqlbinlog --start-position="120" --stop-position="332" /usr/app/mysqllog/mysql-bin.000001 | mysql -uroot -p
备份日志:必须由两个mysqlbinlog 完成
mysqlbinlog --read-from-remote-server --host=host_name --raw
binlog.000001 binlog.000131 binlog.000132
--read-from-remote-server可以用-R替代:连接到服务器并请求其二进制日志, --host:主机ip,
mysqlbinlog --read-from-remote-server --host=host_name --raw
--to-last-log binlog.000001
--raw:写入原始(二进制)输出, binlog.000001:第一个文件, --to-last-log:最后一个文件读完退出
实时读取日志
mysqlbinlog --read-from-remote-server --host=host_name --raw
--stop-never binlog.000001
--stop-never:到达最后一个日志文件的末尾后保持与服务器的连接并继续读取新事件,没有必要指定 --to-last-log读取最后一个日志文件,因为该选项是隐含的。