当前位置: 首页 > news >正文

网站设计的简称石狮建设银行网站

网站设计的简称,石狮建设银行网站,做演示的网站,域名购买后如何建设网站1 错误日志 错误日志(Error Log):错误日志记录了MySQL引擎在运行过程中出现的错误和异常情况。这些错误可能包括启动和关闭问题、数据库崩溃、权限问题等。错误日志对于排查和解决MySQL引擎问题非常有帮助。 改日志默认开启,默认存…

1 错误日志

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

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

show variables like '%log_error%';

mysql> show variables like ‘%log_error%’;

Variable_nameValue
binlog_error_actionABORT_SERVER
log_errorstderr
log_error_serviceslog_filter_internal; log_sink_internal
log_error_suppression_list
log_error_verbosity2
  • 该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_nameValue
log_binON
log_bin_basename/var/lib/mysql/binlog
log_bin_index/var/lib/mysql/binlog.index
log_bin_trust_function_creatorsOFF
log_bin_use_v1_row_eventsOFF
sql_log_binON
  • 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_nameValue
general_logOFF
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.

http://www.yayakq.cn/news/380295/

相关文章:

  • 文明网站的建设与管理几点思考如何做网站的301重定向
  • 曲靖网站制作公司服务器网站打不开
  • 辽宁住房和城乡建设厅网站首页河南网站定制
  • 西宁市网站建设公司网站建设安全规划
  • 郑州汉狮哪家做网站好wordpress推送失败
  • 营销型网站框架图基于html5的美食网页设计
  • 引航博景做的网站网站建设 企业观点
  • 十堰网站seo方法seo搜索优化费用
  • 创建个人网站英文wordpress自动封面
  • 扬州网站seo赣州专业网站推广多少钱
  • 做h5的网站页面设计做电影网站怎么赚钱
  • 网站架设地址安阳论坛最新消息
  • 经典网站代码上海松江品划建设网站
  • 建设工程八大员考试网站企业网站建设方案价格
  • 钱多网站wordpress 商业主题插件
  • 做网站需要企业爬虫python入门
  • 在意派建设好网站后网站png小图标怎么做
  • 专业的教育行业网站制作抖音代运营费用一年多少钱
  • 德州手机网站建设费用微信小程序前端开发框架
  • 实用网站建设知识点成全视频免费高清观看在线动漫
  • wordpress快速仿站视频教程网站基本内容
  • 关于怎么做网站怎么做网站简单的
  • 地信的网站建设如何用vps做网站
  • 高邮网站建设免费网站设计素材
  • 网站建设客户常见问题展示中心展厅设计
  • 自营购物网站建设172分销系统
  • 怎样在网站上做链接wordpress弹出式视频
  • 网站授权管理系统怎么做装修公司名字大全参考
  • 铜仁市网站建设情况某商贸网站建设方案
  • 搜狐快站生成app怎样低成本做网站推广