• Mysql开启日志


    是否启用了日志
    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

  • 相关阅读:
    解决ubuntu下pip安装报错问题:ERROR: Cannot uninstall 'XXXXXXX'. It is a distutils installed project...
    【IMU】【卡尔曼滤波】惯性导航误差微分方程与状态转移方程
    AspNetCore 路由 <3.0>
    AspNetCore 认证 <1.0>
    AspNetCore 鉴权 <2.0>
    apollo学习2:docker集群部署
    C#中HashSet<T>、SortedSet<T>和Hashtable的使用以及所有集合类型的概述
    Spring自带的Objects等工具类(减少繁琐代码)
    五分钟,手撸一个简单的Spring容器
    jdk1.8: Consumer函数
  • 原文地址:https://www.cnblogs.com/rooney/p/2344133.html
Copyright © 2020-2023  润新知