• Mysql 日志管理


    mysql日志——记录着mysql数据库运行期间的操作和信息

    日志作用
    (1)当数据库遭到意外损害,可以通过日志文件来查询出错原因
    (2)利用日志文件进行数据恢复

    日志分类
    (1)二进制日志:以二进制文件的形式记录了数据库中的操作,但是不记录查询语句
    (2)错误日志:记录Mysql服务器的启动、关闭和运行错误等信息
    (3)慢查询日志:记录执行时间超过指定时间的操作
    (4)通用查询日志:记录用户的所有操作,包括启动和关闭MySQL服务、更新语句、查询语句等

    日志设置
    (1)除了二进制日志,其他都是文本文件
    (2)日志文件通常存储在Mysql数据目录下
    (3)默认只启动了错误日志功能,其他需要手工启动
    (4)但启动日志功能会降低Mysql的执行速度,因为一条操作写进日志中是要花时间的

    二进制日志
    (1) 以二进制文件的形式记录了数据库中的操作,但是不记录查询语句
    (2) 也叫变更日志(update log),主要用于记录数据库的变化
    (3) 启动与设置二进制日志:在Mysql的配置文件中,log-bin=DIR/filename
                                       DIR是存放二进制日志的目录;
                                       每启动一次Mysql,该目录下就会生成一个filename.00000x的文件;
                                       目录下还有一个filename.index的文件,用于存储所有二进制文件清单;
                                       如果我们没有设置DIR和filename,则默认在数据目录下以hostname-bin.00000x命名

    # cat /etc/my.cnf|egrep "log-bin"
    log-bin = /data/mysqldb/binlog/mysql-bin
    # ls /data/mysqldb/binlog/
    mysql-bin.000001 mysql-bin.000003 mysql-bin.000005 mysql-bin.000007 mysql-bin.index
    mysql-bin.000002 mysql-bin.000004 mysql-bin.000006 mysql-bin.000008  

    (4)临时停止与启动二进制日志

    -> set sql_log_bin=0; 停止
    -> set sql_log_bin=1; 启动

    (5)注意:二进制日志文件与数据库数据文件最好不要放在同一块硬盘上,如果存放数据文件的硬盘坏了,可以用另一块硬盘的二进制日志来恢复数据

    (6)查看二进制日志:

    # mysqlbinlog mysql-bin.000001

    (7)删除二进制日志:

    //删除所有
    ->reset master;
    //删除00004之前的所有
    ->purge master logs to 'mysql-bin.000004';
    //删除指定日期时间之前的所有
    ->purge master logs to '2016-08-10 15:00:00';

    (8)使用二进制日志还原数据库

    # mysqlbinlog mysql-bin.000001 | mysql -u root -p
    # mysqlbinlog mysql-bin.000002 | mysql -u root -p
    这条命令可以理解为:使用mysqlbinlog读取二进制日志文件然后使用mysql命令还原到数据库中
    注意还原时必须是编号小的先还原

    (9)使用二进制日志文件的pos号|时间点恢复

    //先执行3条操作
    -> create database 2test
    -> create database alvin
    -> drop database 2test
    
    //查看二进制日志,观察每一个命令的起始/结束pos号,和起始/结束时间
    # mysqlbinlog mysql-bin.000001
    
    # at 120
    #160813 15:13:53 server id 706 end_log_pos 217 CRC32 0x781f816e Query    thread_id=21    exec_time=0    error_code=0
    SET TIMESTAMP=1471072433/*!*/;
    SET @@session.pseudo_thread_id=21/*!*/;
    SET @@session.foreign_key_checks=1, @@session.sql_auto_is_null=0, @@session.unique_checks=1, @@session.autocommit=1/*!*/;
    SET @@session.sql_mode=1075838976/*!*/;
    SET @@session.auto_increment_increment=1, @@session.auto_increment_offset=1/*!*/;
    /*!C utf8 *//*!*/;
    SET @@session.character_set_client=33,@@session.collation_connection=33,@@session.collation_server=33/*!*/;
    SET @@session.lc_time_names=0/*!*/;
    SET @@session.collation_database=DEFAULT/*!*/;
    create database 2test
    /*!*/;
    # at 217
    #160813 15:14:11 server id 706 end_log_pos 314 CRC32 0x0fde9820 Query    thread_id=21    exec_time=0    error_code=0
    SET TIMESTAMP=1471072451/*!*/;
    create database alvin
    /*!*/;
    
    //想回到什么哪条命令时的状态,可以指定起始/结束pos号恢复
    # mysqlbinlog --start-position="120" --stop-position="217" mysql-bin.000001 |mysql -u root -p
    
    //日志也会记录下这条恢复语句,我们可以看到这条命令的时间和原来那条一模一样
    # mysqlbinlog mysql-bin.000001 # at 401 #160813 15:13:53 server id 706 end_log_pos 498 CRC32 0x3a899ca5 Query thread_id=21 exec_time=619 error_code=0 SET TIMESTAMP=1471072433/*!*/; create database 2test /*!*/;
    //同理也可以用时间点来恢复
    # mysqlbinlog –start-datetime=”2016-08-13 15:13:53” –stop-datetime=”2016-08-13 15:14:11” mysql-bin.000001 | mysql –uroot –p

    错误日志
    (1)主要用于记录Mysql服务的开启、关闭和错误信息,若服务启动不成功第一件事应该就是去看这个错误日志
    (2)错误日志是默认开启的,且错误日志无法被关闭
    (3)设置错误日志:在配置文件中,log-error=DIR/filename

    # cat /etc/my.cnf |egrep "log-error"
    log-error = /data/mysqldb/log/mysql-error.log
    # ls /data/mysqldb/log
    mysql-error.log 

    (4)删除错误日志

    mysqladmin -u root -p flush-logs
    # ls
    mysql-error.log mysql-slow_query.log

    通用查询日志
    (1)用来记录用户的所有操作:启动和关闭mysql、更新语句、查询语句
    (2)启用和设置通用查询日志:配置文件中,log=DIR/filename
    (3)删除通用查询日志:

    # mysqladmin -u root -p flush-logs
    或 # echo >access.log

    慢查询日志
    (1)记录执行时间超过指定时间的执行语句
    (2)启动和设置慢查询日志:在配置文件中

    log-slow-queries=DIR/filename
    long_query_time=n   //设置时间为n秒,默认为10s

    (3)删除慢查询日志:

    # mysqladmin -u root -p flush-logs 


  • 相关阅读:
    Restful、SOAP、RPC、SOA、微服务之间的区别
    SOA(面向服务的架构.)、RPC(远程过程调用)思想
    facade层,service 层,domain层,dao 层设计
    Mac下配置alias,zsh终端命令别名
    .bash_profile 和.zshrc
    什么是零担物流?零担物流的五大特点
    零担是什么意思,零担物流和快递有什么区别
    idea vm options
    idea中 VM options配置
    ES配置生命周期策略
  • 原文地址:https://www.cnblogs.com/snsdzjlz320/p/5769158.html
Copyright © 2020-2023  润新知