mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

时间:2022-12-24 11:08:56

一.binlog 二进制其它选项

  在二进制日志记录了数据的变化过程,对于数据的完整性和安全性起着非常重要作用。在mysql中还提供了一些其它参数选项,来进行更小粒度的管理。

  1.1 binlog-do-db=db_name

    该选项告诉主服务器,当前db_name库会更新记录到二进制日志中,其它所有没有显示指定的数据库更新时不记录到二进制日志中。

  1.2 binlog-ignore-db=db_name

    该选项告诉主服务器,当前db_name库不会更新记录到二进制日志中,其它所有没有显示指定的数据库会更新到二进制日志中。

    下面来演示下binlog-ignore-db选项。在my.cnf中加上binlog-ignore-db=test。该test库更新时不记录到二进制日志中。my.cnf设置如下图所示:
    mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

    修改my.cnf后,重启mysqld服务,查看最新binlog编号为 000017。
    mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

--在test库的a表中插入一条数据
INSERT INTO a VALUES('cccccc');

    查看binlog二进制日志,发现该插入语句,没有在二进制日志中出现。如下图所示:
    mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

    接下来注释my.cnf中的binlog-ignore-db=test。
    mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

    重启mysqld服务, 查看最新binlog编号为000018。如下图所示:
    mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

--在test库的a表中插入一条数据
INSERT INTO a VALUES('dddddd');

    查看binlog二进制日志,发现该插入语句,已经记录到二进制日志中。如下图所示:
    mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

  总结:

    (1)对于明文的DML语句,使用 如:./mysqlbinlog --base64-output=decode-row -v mysql-bin.000018
    (2)在mysql客户端使用FLUSH LOGS或重启服务会生成新的binlog日志文件序号(已确定 )。
    (3)除了使用mysqlbinlog查看还可以在mysql客户端使用,先设置my.cnf的binlog_rows_query_log_events=1, 开启如下图所示:

      mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志
      SHOW VARIABLES LIKE 'binlog_rows_query_log_events'

      mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

-- 插入数据
INSERT INTO testbackup VALUES(4,'田七')
-- 查看binlog日志
SHOW BINLOG EVENTS IN 'mysql-bin.000029' ;

    mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志
     (4) 使用SHOW MASTER STATUS;查看最新日志
      mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

二. 查询日志general_log

  上面我们知道,在二进制日志里是不包含查询数据的语句。下面可以使用general_log=1选项参数开启,来记录客户端的所有查询语句。log_output=FILE,TABLE 选项参数为输出格式是文件和表。 启动mysqld服务后,查询日志开始被记录。

-- 日志查询是否开启,如果general_log的值为ON则为开启,为OFF则为关闭(默认情况下是关闭的)
SHOW VARIABLES LIKE '%general%';

    mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

-- 输出日志格式为文件还是表
SHOW VARIABLES LIKE '%log_output%';

    mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志

  对于查询日志log这里就不在演示。在log中记录了所有数据库的操作,对于访问频繁的系统,此日志对系统性能的影响较大,一般不建议开启,如果是对查询进行跟踪确认可以打开记录一段时间。

mysql 开发进阶篇系列 40 mysql日志之二进制日志下以及查询日志的更多相关文章

  1. mysql 开发进阶篇系列 20 MySQL Server(innodb_lock_wait_timeout,innodb_support_xa,innodb _log_*)

    1. innodb_lock_wait_timeout mysql 可以自动监测行锁导致的死锁并进行相应的处理,但是对于表锁导致的死锁不能自动监测,所以该参数主要用于,出现类似情况的时候等待指定的时间 ...

  2. mysql 开发进阶篇系列 41 mysql日志之慢查询日志

    一.概述 慢查询日志记录了所有的超过sql语句( 超时参数long_query_time单位 秒),获得表锁定的时间不算作执行时间.慢日志默认写入到参数datadir(数据目录)指定的路径下.默认文件 ...

  3. mysql 开发进阶篇系列 39 mysql日志之二进制日志(binlog)

    一.概述 二进制日志(binlog)记录了所有的DDL(数据定义语言)语句和DML(数据操纵语言)语句,但是不包括数据查询语句, 语句以"事件"的形式保存,它描述了数据的更改过程, ...

  4. mysql 开发进阶篇系列 38 mysql日志之错误日志log-error

    一.mysql日志概述 在mysql中,有4种不同的日志,分别是错误日志,二进制日志(binlog日志),查询日志,慢查询日志.这此日志记录着数据库在不同方面的踪迹(区别sql server里只有er ...

  5. mysql 开发进阶篇系列 16 MySQL Server(myisam key_buffer)

    一.概述 mysql 提供了很多参数来进行服务器的设置,当服务第一次启动的时候,所有启动参数值都是系统默认的.这些参数在很多生产环境下并不能满足实际的应用需求.在这个系列中涉及到了liunx 服务器, ...

  6. mysql 开发进阶篇系列 19 MySQL Server(innodb_flush_log_at_trx_commit与sync_binlog)

    一. innodb_flush_log_at_trx_commit 这个参数名称有个log,一看就是与日志有关.是指:用来控制缓冲区(log buffer)中的数据写入到日志文件(log file), ...

  7. mysql 开发进阶篇系列 18 MySQL Server(innodb_buffer_pool_size)

    从这篇开始,讲innodb存储引擎中,对于几个重要的服务器参数配置.这些参数以innodb_xx 开头. 1. innodb_buffer_pool_size的设置 这个参数定义了innodb存储引擎 ...

  8. mysql 开发进阶篇系列 17 MySQL Server(key_buffer与table_cache)

    一.key_buffer 上一篇了解key_buffer设置,key_buffer_size指定了索引缓冲区的大小,它决定索引处理的速度,尤其是索引读的速度.通过检查状态值Key_read_reque ...

  9. mysql 开发进阶篇系列 55 权限与安全(安全事项 )

    一. 操作系统层面安全 对于数据库来说,安全很重要,本章将从操作系统和数据库两个层面对mysql的安全问题进行了解. 1. 严格控制操作系统账号和权限 在数据库服务器上要严格控制操作系统的账号和权限, ...

随机推荐

  1. C#开发微信门户及应用(22)-微信小店的开发和使用

    在做企业电子商务方面,微信小店虽然较淘宝天猫等起步较晚,但是作为一个电商平台,这个影响力不容忽视,结合微信的特点和便利,微信小店具有很好的粘合性和广泛的用户基础,因此花费一定的时间,在这方面做深入的研 ...

  2. 从SQLite获取数据完成一个产品信息展示

    在ios实际开发当中,我们常常用到Core Data做为数据储存首选.但在处理一些大量复杂的数据值且数据之间相互关联的时候,这就不得不使用关系型数据库来实现.例如一个导航程序,自身应该包含大量的地图自 ...

  3. Emacs常用命令

    1.离开Emacs 挂起Emacs C-z 退出Emacs C-x C-c 2.文件 打开文件 C-x C-f 保存文件 C-x C-s 保存所有的文件 C-x s 将一个文件的内容插入到当前buff ...

  4. ASP.NET- LinkButton 传递多个参数

    在使用LinkButton时可能会遇到需要传递多个参数的问题,而LinkButton的用来传递参数的属性commandargument需要传递的是一个string类型的值.因而传递多个参数时需要进行一 ...

  5. C#使用DataSet类、DataTable类、DataRow类、OleDbConnection类、OleDbDataAdapter类编写简单数据库应用

    //注意:请使用VS2010打开以下的源代码. //源代码地址:http://pan.baidu.com/s/1j9WVR using System; using System.Collections ...

  6. 火星A+B..(不贴代码了)

    还是A+B Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 K (Java/Others)Total Submi ...

  7. Qt5官方demo分析集11——Qt Quick Particles Examples - Affectors

    在这个系列中的所有文章都可以在这里查看http://blog.csdn.net/cloud_castle/article/category/2123873 接上文Qt5官方demo解析集10--Qt ...

  8. 异常:cvc-complex-type.2.4.a: Invalid content was found starting with element

    web.xml 出现cvc-complex-type.2.4.a: Invalid content was found starting with element <web-app xmlns= ...

  9. MySql基础入门-mysql体系结构

    mysql体系结构:     由:连接池组件.管理服务和工具组件.sql接口组件.查询分析器组件.优化器组件.                缓冲组件.插件式存储引擎.物理文件组成.     mysq ...

  10. 使用mysqlslap进行MySQL压力测试

    使用mysqlslap进行MySQL压力测试发表于236 天前 ? MySQL ? 暂无评论 MySQL从5.1.4版开始带有一个压力测试工具mysqlslap,通过模拟多个并发客户端访问mysql来 ...