mysql>show variables like 'log_bin';
怎样知道当前的日志
mysql> show master status;
看二进制日志文件用mysqlbinlog
shell>mysqlbinlog mail-bin.000001(要写绝对问题路径 d://)
或者shell>mysqlbinlog mail-bin.000001 | tail
mysql有以下几种日志:
错误日志: -log-err
查询日志: -log
慢查询日志: -log-slow-queries
更新日志: -log-update
二进制日志: -log-bin
在mysql的安装目录下,打开my.ini,在后面加上上面的参数,保存后重启mysql服务就行了。
例如:
#Enter a name for the error log file. Otherwise a default name will be used.
log-error=err.log
#Enter a name for the query log file. Otherwise a default name will be used.
#log=
#Enter a name for the slow query log file. Otherwise a default name will be used.
#log-slow-queries=
#Enter a name for the update log file. Otherwise a default name will be used.
#log-update=
#Enter a name for the binary log. Otherwise a default name will be used.
#log-bin=
上面只开启了错误日志,要开其他的日志就把前面的“#”去掉。
long_query_time =1 --是指执行超过多久的sql会被log下来,这里是1秒
log-slow-queries=slowqueris.log --将查询返回较慢的语句进行记录
log-queries-not-using-indexes = nouseindex.log --就是字面意思,log下来没有使用索引的query
log=mylog.log --对所有执行语句进行记录
log-error=log-error.log
log=log-query.log
log-queries-not-using-indexes
log-warnings=2
log-slow-queries=log-slow-query.log
log-update=log-update.log
long_query_time=2
1. 指定恢复时间语法
假如你今天早上9点不小心砍掉哪個资料库的资料表,你可以利用下面语法来恢复
mysqlbinlog --stop-date="2007-03-29 8:59:59" /var/lib/mysql/bin.000001 | mysql -u root -p
如果你想恢复后面9点以后sql语法 可以使用
mysqlbinlog --start-date="2007-03-29 9:00:00" /var/lib/mysql/bin.000001 | mysql -u root -p
或者是 你想恢复 9点到10点之间的sql语法,则下面语法是您想要的
mysqlbinlog --start-date="2007-03-29 9:00:00" --stop-date="2007-03-29 10:00:00" /var/lib/mysql/bin.000001 | mysql -u root -p
其實你也可以不要执行,先把sql语法输出到 /tmp/restore.sql
mysqlbinlog --start-date="2007-03-29 9:00:00" --stop-date="2007-03-29 10:00:00" /var/lib/mysql/bin.000001 > /tmp/restore.sql
当然 你也可以指定你要输出的 database,免的档案很大
--database=db_name,-d db_name
--host=host_name,-h host_name