• 售前

  • 售后

热门帖子
入门百科

MySQL系列之十一 日志记载

[复制链接]
123456819 显示全部楼层 发表于 2021-8-14 15:04:38 |阅读模式 打印 上一主题 下一主题
系列教程

MySQL系列之开篇 MySQL关系型数据库根本概念
MySQL系列之一 MariaDB-server安装
MySQL系列之二 多实例配置
MySQL系列之三 根本篇
MySQL系列之四 SQL语法
MySQL系列之五 视图、存储函数、存储过程、触发器
MySQL系列之六 用户与授权
MySQL系列之七 MySQL存储引擎
MySQL系列之八 MySQL服务器变量
MySQL系列之九 mysql查询缓存及索引
MySQL系列之十 MySQL事务隔离实现并发控制
MySQL系列之十一 日志记录
MySQL系列之十二 备份与规复
MySQL系列之十三 MySQL的复制
MySQL系列之十四 MySQL的高可用实现
MySQL系列之十五 MySQL常用配置和性能压力测试
一、SQL下令汗青
  1. ~/.mysql_history
复制代码
记录了在mysql中实行的下令汗青
二、事务日志

transaction log:事务型存储引擎自行管理和使用
  1. 在一个事务提交后还没有存到磁盘的情况下会记录到事务日志,这个时候如果系统断电,再次开机后会自动将已提交的事务重做(redo log)写入磁盘;如果事务还没有提交的情况下断电重启后会执行撤销操作(undo log)
复制代码
相干变量
  1. MariaDB [school]> SHOW VARIABLES LIKE 'innodb_log%';
  2. +---------------------------+------------+
  3. | Variable_name             | Value      |
  4. +---------------------------+------------+
  5. | innodb_log_block_size     | 512        | -- 块大小
  6. | innodb_log_buffer_size    | 8388608    | -- 缓存大小
  7. | innodb_log_file_size      | 1073741824 | -- 每个日志文件大小
  8. | innodb_log_files_in_group | 3          | -- 日志组成员个数,也就是有几个文件
  9. | innodb_log_group_home_dir | ./         | -- 事务文件路径,相对于数据目录
  10. +---------------------------+------------+
复制代码
  1. innodb_log_file_size默认大小为5M,innodb_log_files_in_group个数默认2个;强烈建议调大这俩个值;
  2. 如果事务操作的数据大于事务日志文件总大小,在执行ROLLBACK时:可以撤销,但是数据文件会被占用,需要使用OPTIMIZE TABLE命令来释放数据空间;
  3. 使用TRUNCATE删除表记录可以缩小占用空间,DELETE命令不会释放磁盘空间,如果需要释放需要使用OPTIMIZE命令从新整理碎片来释放空间。
复制代码
注意:修改innodb_log_file_size时必要先删除原来的日志文件
三、错误日志

错误日志中记录项目:
       
  • mysqld启动和关闭过程中输出的事件信息   
  • mysqld运行中产生的错误信息   
  • event scheduler运行一个event时产生的日志信息   
  • 在主从复制架构中的从服务器上启动从服务器线程时产生的信息
相干变量
  1. MariaDB [school]> SHOW GLOBAL VARIABLES LIKE 'log_error';  #错误日志文件的路径
  2. +---------------+------------------------------+
  3. | Variable_name | Value                        |
  4. +---------------+------------------------------+
  5. | log_error     | /var/log/mariadb/mariadb.log |
  6. +---------------+------------------------------+
复制代码
  1. log_warnings=1|0 
复制代码
默认值1(是):是否记录告诫信息至错误日志文件
四、查询日志

记录用户的利用日志,一样寻常不建议启用
  1. MariaDB [school]> SHOW VARIABLES LIKE 'general_log%';
  2. +------------------+-------------+
  3. | Variable_name    | Value       |
  4. +------------------+-------------+
  5. | general_log      | OFF         | -- 开启关闭通用日志,默认关闭
  6. | general_log_file | centos7.log | -- 通用日志文件的文件名,/var/lib/mysql/HOSTNAME.log
  7. +------------------+-------------+
复制代码
  1. MariaDB [school]> SHOW VARIABLES LIKE 'log_output';  
  2. +---------------+-------+
  3. | Variable_name | Value |
  4. +---------------+-------+
  5. | log_output    | FILE  | -- 以什么方式存放日志,(TABLE|FILE|NONE)
  6. +---------------+-------+
复制代码
  1. mysql.general_log:表存放查询日志,前提是以表方式存放的
复制代码
五、慢查询日志

记录实行查询时长超出指定时长的利用
1、慢查询相干变量
  1. MariaDB [school]> SHOW VARIABLES LIKE 'slow_query%';   
  2. +---------------------+------------------+
  3. | Variable_name       | Value            |
  4. +---------------------+------------------+
  5. | slow_query_log      | OFF              | -- 开启或关闭慢查询日志
  6. | slow_query_log_file | centos7-slow.log | -- 慢查询日志文件
  7. +---------------------+------------------+
  8. MariaDB [school]> SHOW VARIABLES LIKE 'long_query_time';
  9. +-----------------+-----------+
  10. | Variable_name   | Value     |
  11. +-----------------+-----------+
  12. | long_query_time | 10.000000 | -- 慢查询的阀值,单位秒,查询时间超过10则记录到慢查询日志
  13. +-----------------+-----------+
  14. MariaDB [school]> SHOW VARIABLES LIKE 'log_slow%';
  15. +---------------------+-------+
  16. | Variable_name       | Value |
  17. +---------------------+-------+
  18. | log_slow_rate_limit | 1     | -- 多少次查询才记录,mariadb特有
  19. | log_slow_verbosity  |       | -- 记录内容的详细程度(Query_plan,explain)
  20. +---------------------+-------+
  21. MariaDB [school]> SHOW VARIABLES LIKE 'log_queries_not_using_indexes';
  22. +-------------------------------+-------+
  23. | Variable_name                 | Value |
  24. +-------------------------------+-------+
  25. | log_queries_not_using_indexes | OFF   | -- 记录没有利用索引查询,而使用全文扫描的语句;默认关闭,建议开启
  26. +-------------------------------+-------+
复制代码
  1. log_slow_filter
复制代码
:根据查询效果过滤
       
  • admin   
  • filesort   
  • filesort_on_disk   
  • full_join   
  • full_scan   
  • query_cache   
  • query_cache_miss   
  • tmp_table   
  • tmp_table_on_disk
2、增补:利用
  1.  profiling 
复制代码
跟踪查询语句所用的具体时间

  1. MariaDB [school]> SHOW VARIABLES LIKE 'profiling';+---------------+-------+| Variable_name | Value |+---------------+-------+| profiling     | OFF   | -- 开启或关闭,默认关闭+---------------+-------+MariaDB [school]> SET profiling=ON;  #开启查询语句跟踪功能MariaDB [school]> SHOW profiles;  #查询语句实行的时间列表+----------+------------+------------------------------------------------------------+| Query_ID | Duration   | Query                                                      |+----------+------------+------------------------------------------------------------+|        1 | 0.00024497 | SELECT * FROM students                                     ||        2 | 0.00038528 | SELECT stuid,name,age FROM students WHERE stuid = 2        |+----------+------------+------------------------------------------------------------+
复制代码
  1. MariaDB [school]> SHOW profile FOR query 2;  #查询指定编号的SQL语句的详细执行过程
  2. +----------------------+----------+
  3. | Status               | Duration |
  4. +----------------------+----------+
  5. | starting             | 0.000035 |
  6. | Opening tables       | 0.000003 |
  7. | After opening tables | 0.000006 |
  8. | query end            | 0.000003 |
  9. | closing tables       | 0.000002 |
  10. | freeing items        | 0.000011 |
  11. | updating status      | 0.000006 |
  12. | cleaning up          | 0.000001 |
  13. +----------------------+----------+
复制代码
六、二进制日志

记录已提交事务导致数据改变或潜在导致数据改变的SQL语句,通过“重放”日志文件中的事件来生成数据副本,不依赖存储引擎范例。
  1. 开启二进制日志,默认是关闭的,二进制日志和数据分开存放
复制代码
开启记录二进制文件的功能:在my.cnf的[mysqld]下参加l
  1. og_bin[=/path/somefile]
复制代码
默认二进制日志在数据库目录下,
  1. mariadb-bin.000001 
复制代码
为二进制日志数据文件,
  1. mariadb-bin.index
复制代码
为二进制日志索引文件
1、记录二进制日志的三种方式:

       
  • 基于语句的记录方式,每一条改变数据的语句记录为一条语句,节流空间,体系默以为此模式,但是不保举使用,会有隐藏的风险   
  • 基于行的记录方式,每一行的改变都会将使其改变的语句记录为一条语句,日志量会很大,但是对数据的安全掩护非常高   
  • 混淆模式:mixed, 让体系自行判定该基于哪种方式举行
  1. MariaDB [(none)]> SHOW VARIABLES LIKE 'binlog_format';  
  2. +---------------+-----------+
  3. | Variable_name | Value     |
  4. +---------------+-----------+
  5. | binlog_format | STATEMENT | -- 记录方式,系统默认基于语句方式
  6. +---------------+-----------+
复制代码
  1. SET binlog_format='ROW|STATEMENT|MIXED'; -- 修改二进制日志记录方式
复制代码
2、二进制日志的相干变量
  1. MariaDB [(none)]> SHOW MASTER|BINARY LOGS; -- 查看mariadb自行管理使用中的二进制日志文件列表
  2. +--------------------+-----------+
  3. | Log_name           | File_size |
  4. +--------------------+-----------+
  5. | mariadb-bin.000002 |       290 |
  6. | mariadb-bin.000003 |       264 |
  7. | mariadb-bin.000004 |    529038 |
  8. | mariadb-bin.000005 |       245 |
  9. +--------------------+-----------+
  10. MariaDB [(none)]> SHOW MASTER STATUS; -- 查看使用中的二进制日志文件
  11. +--------------------+----------+--------------+------------------+
  12. | File               | Position | Binlog_Do_DB | Binlog_Ignore_DB |
  13. +--------------------+----------+--------------+------------------+
  14. | mariadb-bin.000005 |      245 |              |                  |
  15. +--------------------+----------+--------------+------------------+
  16. MariaDB [(none)]> SHOW BINLOG EVENTS IN 'mariadb-bin.000004' FROM 1 LIMIT 2,3\G -- 查看二进制文件中的指定内容
复制代码
  1. MariaDB [(none)]> SHOW VARIABLES LIKE 'sql_log_bin'; -- 是否记录二进制日志,默认ON
  2. MariaDB [(none)]> SHOW VARIABLES LIKE 'log_bin'; -- 指定文件位置;默认OFF,表示不启用二进制日志功能,上述两项都开启才可
  3. MariaDB [(none)]> SHOW VARIABLES LIKE 'max_binlog_size';
  4. +-----------------+------------+
  5. | Variable_name   | Value      |
  6. +-----------------+------------+
  7. | max_binlog_size | 1073741824 | -- 单个二进制日志文件的最大体积,到达最大值会自动滚动,默认为1G
  8. +-----------------+------------+
  9. MariaDB [(none)]> SHOW VARIABLES LIKE 'sync_binlog';   
  10. +---------------+-------+
  11. | Variable_name | Value |
  12. +---------------+-------+
  13. | sync_binlog   | 0     | -- 设定是否启动二进制日志即时同步磁盘功能,默认0,由操作系统负责同步日志到磁盘
  14. +---------------+-------+
  15. MariaDB [(none)]> SHOW VARIABLES LIKE 'expire_logs_days';
  16. +------------------+-------+
  17. | Variable_name    | Value |
  18. +------------------+-------+
  19. | expire_logs_days | 0     | -- 二进制日志可以自动删除的天数。 默认为0,即不自动删除
  20. +------------------+-------+
复制代码
3、mysqlbinlog下令

       
  • 二进制日志的客户端下令工具   
  • --start-position=# 指定开始位置   
  • --stop-position=# 指定竣事位置   
  • --start-datetime=(YYYY-MM-DD hh:mm:ss) 指定开始时间   
  • --stop-datetime=(YYYY-MM-DD hh:mm:ss) 指定竣事时间   
  • --base64-output=decode-row   
  • -v |-vv |-vvv |-vvvv 显示具体信息
  1. [root@centos7 mysql]# mysqlbinlog --start-position=528864 --stop-position=529019 mariadb-bin.000004 --base64-output=decode-row -v
  2. # at 528864
  3. #180611 20:59:46 server id 1  end_log_pos 528992        Query   thread_id=29    exec_time=0     error_code=0
  4. use `school`/*!*/;
  5. SET TIMESTAMP=1528721986/*!*/;
  6. INSERT students(StuID,Name,Age,Gender) VALUES (26,'Tom',22,'M')  #改变数据的SQL语句
  7. /*!*/;
  8. 事件发生的日期和时间:180611 20:59:46
  9. 事件发生的服务器标识:server id 1
  10. 事件的结束位置:end_log_pos 528992
  11. 事件的类型:Query
  12. 事件发生时所在服务器执行此事件的线程的ID:thread_id=29
  13. 语句的时间戳与将其写入二进制文件中的时间差:exec_time=0
  14. 错误代码:error_code=0
  15. 事件内容:
  16. GTID:Global Transaction ID,mysql5.6以mariadb10以上版本专属属性:GTID
复制代码
使用
  1. mysqlbinlog mariadb-bin.000001 > file.sql
复制代码
下令重定向到SQL文件中,再使用
  1. mysql -uroot -p < file.sql
复制代码
下令可以直接导入数据,实现了备份还原的功能
4、二进制日志的管理
  1. MariaDB [(none)]> PURGE BINARY LOGS TO 'mariadb.000002'; -- 删除到02,注意:02不删除
  2. MariaDB [(none)]> PURGE BINARY LOGS BEFORE '2018-01-23'; -- 删除2018-01-23之前的日志
  3. MariaDB [(none)]> PURGE BINARY LOGS BEFORE '2017-03-22 09:25:30';
  4. MariaDB [(none)]> RESET MASTER; -- 删除所有二进制日志,index文件重新记数
  5. MariaDB [(none)]> FLUSH LOGS; -- 手动触发日志滚动
复制代码
七、中继日志
  1. relay log
复制代码
:主从复制架构中,从服务器用于生存从主服务器的二进制日志中读取到的事件
总结

本篇文章就到这里了,希望可以给你带来一些资助,也希望您能够多多关注草根技术分享的更多内容!

帖子地址: 

回复

使用道具 举报

分享
推广
火星云矿 | 预约S19Pro,享500抵1000!
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

草根技术分享(草根吧)是全球知名中文IT技术交流平台,创建于2021年,包含原创博客、精品问答、职业培训、技术社区、资源下载等产品服务,提供原创、优质、完整内容的专业IT技术开发社区。
  • 官方手机版

  • 微信公众号

  • 商务合作