0101日志-运维-mysql

2023-11-06

1 错误日志

错误日志(Error Log):错误日志记录了MySQL引擎在运行过程中出现的错误和异常情况。这些错误可能包括启动和关闭问题、数据库崩溃、权限问题等。错误日志对于排查和解决MySQL引擎问题非常有帮助。

改日志默认开启,默认存放目录/var/log,默认日志文件名称`mysqld.log。查看日志文件位置:

show variables like '%log_error%';

mysql> show variables like ‘%log_error%’;

Variable_name Value
binlog_error_action ABORT_SERVER
log_error stderr
log_error_services log_filter_internal; log_sink_internal
log_error_suppression_list
log_error_verbosity 2
  • 该mysql为docker容器中安装运行,位置为标准的错误输出。

下面我们通过修改auto.cnf中UUID让mysql启动报错,来演示错误。

/var/lib/mysql/auto.cnf内容如下所示:

[auto]
server-uuid=1ceab188-df23-11ed-ab6f-0242ac110002

mysql服务器uuid唯一且位数固定,现在我们删去最后一位,再次启动mysql

在这里插入图片描述

报错信息显示auto.cnf中UUID非法无效,现在我们改回之前的server-uuid,问题来了,我们的mysql之前未挂载msyql目录,现在mysql容器启动不起来,不能进入容器,修改不了auto.cnf文件了怎么办呢?

在这里插入图片描述

首先要记住一点,你看不到不表示它没有。

第二步:把mysql文件夹下载到本地,右键save本地

在这里插入图片描述

第三步:修改mysql/auto.cnf为原server-uuid,右键import 在上传至原位置。

2 二进制日志

2.1 简介

二进制日志(BINLOG)记录所有的DDL(数据定义语言)语句和MDL(数据操纵语言)语句,但不包括(SELECT、SHOW)语句。

  • 作用:
    • 灾难时数据恢复;
    • Mysql的主从复制;

二进制日志查看

show variables like '%log_bin%';
Variable_name Value
log_bin ON
log_bin_basename /var/lib/mysql/binlog
log_bin_index /var/lib/mysql/binlog.index
log_bin_trust_function_creators OFF
log_bin_use_v1_row_events OFF
sql_log_bin ON
  • Log_bin:二进制日志开关,mysql8.0默认开启;
  • log_bin_basename: 二进制日志文件存放路径和基础文件名binlog;
  • log_bin_index:二进制日志文件对应的索引记录

2.2 日志格式

Mysql服务器提供多种格式来记录二进制日志,具体格式及特点如下:

日志格式 含义
STATEMENT 基于SQL语句的日志记录,记录的是SQL语句,对数据修改的SQL都会记录在日志中。
ROW 基于行的日志记录,记录的是每一行的数据变更。(默认)
MIXED 混合STATEMNET和ROW记录,默认采用STATEMENT记录,在某些特殊的情况下自动切换ROW记录。

查看日志格式

show variables like '%binlog_format%';
binlog_format | ROW 

2.3 日志查看

由于日志以二进制存储,不能直接读取,需要通过二进制日志查询工具mysqlbinlog查看,具体语法

mysqlbinlog [参数选项] logfilename
参数选项:
	-d	指定数据库名称,只列出指定数据库相关操作。
	-o 	忽略掉日志文件中的前n行
	-v	将行事件(数据变更)重构为sql语句
	-w	将行事件(数据变更)重构为sql语句,并输出注释信息
  • 基于行的日志记录

对score表执行如下sql

update score set math = math+1;

查看日志文件binlog.000071,

mysqlbinlog -v binlog.000071

### UPDATE `gaogzhen`.`score`
### WHERE
###   @1=1
###   @2='Java'
###   @3=66
###   @4=88
###   @5=95
### SET
###   @1=1
###   @2='Java'
###   @3=67
###   @4=88
###   @5=95
### UPDATE `gaogzhen`.`score`
### WHERE
###   @1=2
###   @2='Rose'
###   @3=90
###   @4=66
###   @5=99
### SET
###   @1=2
###   @2='Rose'
###   @3=91
###   @4=66
###   @5=99
### UPDATE `gaogzhen`.`score`
### WHERE
###   @1=3
###   @2='Java'
###   @3=98
###   @4=77
###   @5=80
### SET
###   @1=3
###   @2='Java'
###   @3=99
###   @4=77
###   @5=80

  • where 记录是的更新前的数据;set记录更新后的数据。

  • @1表示第一列

  • 基于STATEMENT的日志格式

在my.cnf中设置

binlog_format=STATEMENT

重启mysql,生成新的日志文件,执行相同的sql操作,再次查看日志内容

update score set math=math+1

2.4 日志删除

对于比较繁忙的业务系统,每天生成的binlog数量巨大,如果长时间不清除,将会占用大量磁盘空间。可以通过以下几种方式清理:

指令 含义
reset master 删除全部binlog日志,删除之后,日志编号,将从binlog.000001开始
purge master logs to ‘binlog.*****’ 删除* 编号之前的日志
purge master logs before ‘yyyy-mm-dd hh24:mi:ss’ 删除指定时间之前的日志

也可以在mysql的配置文件中配置二进制日志的过期时间,设置之后,二进制日志过去会自动删除

show variables like '%binlog_expire_logs_seconds%';

binlog_expire_logs_seconds | 2592000 默认30天

3 查询日志

查询日志中记录了客户端的所有操作语句,而二进制日志不包含查询数据的SQL语句。默认情况下,查询日志是未开启的。如果需要开启查询日志,可以开启以下设置。

show variables like '%general%'
Variable_name Value
general_log OFF
general_log_file /var/lib/mysql/a584ba590640.log

第一步my.cnf配置查询日志

general_log=ON
general_log_file=/var/lib/mysql/mysql_query.log

第二步执行sql操作,查看配置的查询日志

tail -f mysql_query.log

如下图所示:

在这里插入图片描述

在业务繁忙的系统中开启查询日志,查询日志会非常大,如果非不要不建议开启。

4 慢查询日志

慢查询日志记录了所有时间超过参数long_query_time设置值并且扫描记录数不小于min_examined_row_limit的所有的SQL语句的日志,默认未开启。long_query_time默认10s,最小为0,精度可以到微妙。

第一步配置my.cnf中慢查询

slow_query_log=1
slow_query_log_file=/var/lib/mysql/slow-log.log
long_query_time=2
  • slog_query_log:1开启慢查询日志
  • slow_query_log_file:设置慢查询日志文件
  • long_query_time:设置阈值时间

第三步:查看慢查询日志,操作数据库

tail -f slow_log.log

如下图所示:

在这里插入图片描述

默认情况下,不会记录管理语句,也不会记录不使用索引进行查询的语句。可以使用log_slo_admin_statementslog_queries_not_using_indexes

# 记录执行较慢的管理语句
log_slow_admin_statements=1
# 记录较慢的未使用索引的语句
log_queries_not_using_indexes=1

结语

如果小伙伴什么问题或者指教,欢迎交流。

❓QQ:806797785

参考链接:

[1]MySQL数据库视频[CP/OL].2020-04-16.p153-157.

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

0101日志-运维-mysql 的相关文章

随机推荐

  • Graft货币(GRFT)结点搭建

    Graft官网 https www graft network github地址 https github com graft project GraftNetwork releases 节点搭建 从https github com gra
  • MPC车辆轨迹跟踪----理论推导

    MPC控制简介 众所周知 控制算法中 PID的应用占据了90 而另外10 就是这次的主角MPC控制算法 MPC控制算法全称模型预测控制 它相对比PID有着多输入 多输出以及更加平稳的特点 并且最重要的是 MPC可以针对非线性的系统进行控制
  • PCB正片和负片有什么区别

    PCB正片和负片有什么区别 概念 正片和负片是底片的两种不同类型 正片 简单地说就是 在底片上看到什么就有什么 负片 正好相反 看到的就是没有的 看不到的就是有的 见下图 在 Allegro中使用正负片的特点 正片 优点是所见所的 有比较完
  • IDEA 2018 Mybatis Plugin插件安装破解及使用

    一 进入官网http plugins jetbrains com 二 搜索Free MyBatis Plugin 三 点击get 选择Free Mybatis plugin 点击下载 四 下载完成 五 打开Idea 点击File 点击Set
  • ARM汇编基础详解(PS学习汇编的原因)

    目录 前言 1 GNU 汇编语法 2 Cortex A7 常用汇编指令 2 1 处理器内部数据传输指令 内部寄存器数据非内存数据 2 2 存储器访问指令 RAM 2 3 压栈和出栈指令 了解 2 4 跳转指令 2 5 算术运算指令 2 6
  • brew 安装 for Mac

    安装命令 usr bin ruby e curl fsSL https raw githubusercontent com Homebrew install master install brew 官网 http brew sh 安装过程遇
  • 电子学会2022年09月青少年软件编程C语言等级考试试卷二级真题及(参考答案)

    编程题 共5题 共100分 1 统计误差范围内的数 考试题目 统计一个整数序列中与指定数字m误差范围小于等于X的数的个数 时间限制 5000 内存限制 65536 输入 输入包含三行 第一行为N 表示整数序列的长度 N lt 100 第二行
  • 代码静态扫描工具sonar介绍

    一 SonarQube整体介绍 SonarQube为静态代码检查工具 采用B S架构 帮助检查代码缺陷 改善代码质量 提高开发速度 通过插件形式 可以支持Java C C JavaScripe等等二十几种编程语言的代码质量管理与检测 通过客
  • 右值引用详解

    何谓右值 右值引用 右值引用与其他对比 右值引用与移动语义 右值引用与std move 移动语义与std move 移动语义注意事项 移动语义与swap 完美转发 何谓右值 一个最简单判断左值 右值的方式是 等号左边的值即左值 等号右边的值
  • 深度学习之浅见

    通常来说 大家认为深度学习的观点是Geoffrey Hinton在2006年提出的 这一算法提出之后 得到了迅速的发展 关于深度学习 zouxy09的专栏中有详细的介绍 Free Mind 的博文也很值得一读 本博文是我对深度学习的一点看法
  • VS Code Remote Development

    在Windows下编辑Linux代码 并且有Linux下的系统接口 第三方dep库的语法解析 代码提示 自动补全 跳转 用起来真香 困扰了Linux后台开发人员多年的难题终极解决方案 要求VS Code版本在1 35 1以上 1 安装远程开
  • 基础学习JavaScript 之 Array

    笔记文 Array JavaScript内置对象之一 由索引值来排序的数据集合 下面就列出了array上的方法 会改变自身的方法 copyWithin 在数组内部 将一段元素序列拷贝到另一段元素序列上 覆盖原有的值 fill 将数组中指定区
  • dc-9 靶机渗透学习

    信息收集 用nmap扫描当前网段 nmap sP 192 168 202 0 24 对靶机进行端口扫描 nmap A p v 192 168 202 148 访问靶机的80端口 进行框架识别 无框架的页面 尝试web服务漏洞 用dirsea
  • java数据结构-栈

    栈 1 栈的定义 栈 Stack 是只允许在一端进行插入或删除的线性表 首先栈是一种线性表 但限定这种线性表只能在某一端进行插入和删除操作 栈顶 Top 线性表允许进行插入删除的那一端 栈底 Bottom 固定的 不允许进行插入和删除的另一
  • VMware+CentOS7搭建私有云桌面服务

    VMware CentOS7搭建私有云桌面服务 1 安装VMware虚拟机工作台 官网下载安装包 版本 14 1 3 Pro 地址 https my vmware com en web vmware info slug desktop en
  • 详解从0开始的嵌入式学习路线,学什么、怎么学?

    嵌入式是个大筐 什么都可以往里面装 电子 机械 计算机 自动化 测控 通信 物联网 很多很多专业都和嵌入式沾边 硬件 驱动 操作系统 网络 应用 算法 很多同学越学越迷糊 越学越感觉什么也不会 首先要记住一句话 嵌入式学习奥义 先观其广 再
  • osgEarth的Rex引擎原理分析(五十八)osgEarth::ShaderFactory osgEarth::ShaderLoader关系

    目标 五十四 中的问题130 osgEarth ShaderFactory osgEarth ShaderLoader关系 ShaderFactory主要用来产生各个着色器阶段的main函数 一般用户不需要直接使用它 除非有特殊的定制需要
  • [CTF]抓住那只猫(XCTF 4th-WHCTF-2017)

    原作者 darkless 题目描述 抓住那只猫 思路 打开页面 有个输入框输入域名 输入baidu com进行测试 发现无任何回显 输入127 0 0 1进行测试 发现已经执行成功 执行的是一个ping命令 一开始想的应该是命令拼接执行 但
  • React18的useEffect会执行两次

    React18的useEffect会执行两次 一 执行两次的useEffect 二 React18 useEffect 新特性 如何应对 1 首先先了解一下 React 中 useEffect 执行的时机 2 怎么样才能让 Effect 执
  • 0101日志-运维-mysql

    1 错误日志 错误日志 Error Log 错误日志记录了MySQL引擎在运行过程中出现的错误和异常情况 这些错误可能包括启动和关闭问题 数据库崩溃 权限问题等 错误日志对于排查和解决MySQL引擎问题非常有帮助 改日志默认开启 默认存放目