mysql日志

mysql有以下几种日志:

错误日志: log-error

查询日志: log

慢查询日志: log-slow-queries

更新日志: log-update

二进制日志: log-bin

主从中继日志:relay_log

在配置文件中指定log的輸出位置.

# vi /etc/my.cnf

[mysqld]

log-error=/usr/local/mysql/logs/error.log       (指定错误日志存放位置)

log=/usr/local/mysql/logs/sql.log         (对所有执行语句进行记录)

long_query_time=2                 (执行超过2秒的sql会被log下来)

log-slow-queries= /usr/local/mysql/logs/slowquery.log       (将查询返回较慢的语句进行记录)

log-queries-not-using-indexes = nouseindex.log     (log下来没有使用索引的sql语句)

log-bin=/usr/local/mysql/logs/mysql-bin        (设置二进制日志的保存位置,/usr/local/mysql/logs为

路径,mysql-bin为文档前缀,注意给/usr/local/mysql/logs可写入的权限)

expire_logs_day=7                                   (设置二进制日志的保存时间为7天,7天后自动删除

)

log_bin=/usr/local/mysql/logs/relaylog      (设置主从mysql中继日志路径为/usr/local/mysql/logs,格

式为relaylog.00001)

:wq

默认情况下,所有日志创建于mysqld数据目录中。

通过刷新日志,你可以强制 mysqld来关闭和重新打开日志文件(或者在某些情况下切换到一个新的日志)。

刷新日志的命令:

> flush logs

# mysqladmin -u root -p flush-logs

# mysqladmin -u root -p refresh

是否启用了日志

mysql> show variables like 'log_%';

怎样知道当前的日志

mysql> show master status;

显示二進制日志数目

mysql> show master logs;

看二进制日志文件用mysqlbinlog

# mysqlbinlog /var/lib/mysql/log/mysql-bin-log.00001

删除全部日志

> reset master;

删除000007编号之前的所有日志

> purge master logs to 'mysql-bin.000007';

删除2012-02-30 23:59:59时间之前的日志

> purge master logs before '2012-02-30 23:59:59';

mysql自带了一个查看慢日志的工具mysqldumpslow。

执行mysqldumpslow –h可以查看帮助信息。

主要介绍两个参数-s和-t

-s 这个是排序参数,可选的有:

al: 平均锁定时间

ar: 平均返回记录数

at: 平均查询时间

c: 计数

l: 锁定时间

r: 返回记录

t: 查询时间

-t n 显示头n条记录。

实例:

mysqldumpslow -s c -t 20 host-slow.log           (访问次数最多的20个sql语句)

mysqldumpslow -s r -t 20 host-slow.log           (返回记录集最多的20个sql)

mysqldumpslow -t 10 -s t -g “left join” host-slow.log         (按照时间返回前10条里面含有左连

接的sql语句)

日志恢复:

bin-log是记录着mysql所有事件的操作,当mysql发生灾难性错误时,可以通过bin-log做完整恢复,基于时间

点的恢复,和基于位置的恢复

完整恢复:

假定我们每天凌晨2点都会使用mysqldump备份数据库,但在第二天早上9点由于数据库出现了故障,数据无法访

问,需要恢复数据,先使用昨天凌晨备份的文件进行恢复到凌晨2点的状态,在使用mysqlbinlog恢复自

mysqldump备份以来的binlog

这样数据库就可以完全的恢复到崩溃前的完全状态

基于时间点的恢复:

由于误操作,比如说删除了一张表,这时使用上面讲的完全恢复是没有用的,因为日志里面还存在误操作的语

句,,我们需要的是恢复到误操作前的状态,然后跳过误操作的语句,再恢复后面操作的语句,假定我们删除

了一张表的误操作发生在10:00这个时间点,我们可以使用下面的语句用备份和binlog将数据恢复到故障前

# mysqlbinlog --stop-date='2010-09-04 9:59:59' /var/log/mysql-bin.000001 | mysql -u root -p

然后跳过误操作的时间点,继续执行后面的binlog

# mysqlbinlog --start-date='2010-09-04 10:01:00' /var/log/mysql-bin.000001 | mysql -u root -p

其中--stop-date='2010-09-04 9:59:59' 和 --start-date='2010-09-04 10:01:00' 其中的时间是你误操作的

时间点,当然了,这个时间点你需要你自己计算的,而且这个时间点还可以涉及到的不只是误操作,还可以有

正确的操作也被跳过去了。

基于位置恢复:

由于上面提到的,使用基于时间点的恢复可能出现,在一个时间点里面可能存在误操作和其他正确的操作,所

以我们需要一种更为精确的恢复方式

使用mysqlbinlog查看二进制,可看到

其中drop tables test1这个误操作的end_log_pos为8879917,记下这个id,得出它前后操作的id分别为

8879916,8879918

我们将进行位置恢复操作

# mysqlbinlog --stop-position='8879916' /var/log/mysql-bin.000001 | mysql -u root -p

# mysqlbinlog --start-position='8879918' /var/log/mysql-bin.000001 | mysql -u root -p

第一行是恢复到停止位置位置的所以事务,第二性是恢复从给定的起始位置知道二进制日志结束所有事物。

本文转自linux博客51CTO博客,原文链接http://blog.51cto.com/yangzhiming/834893如需转载请自行联系原作者

yangzhimingg

阿里云mysql 日志_mysql日志-阿里云开发者社区相关推荐

  1. 阿里云 mysql 日志_MySQL日志简介-阿里云开发者社区

    MySQL中的日志主要分为以下几种: 查询日志 慢查询日志 错误日志 二进制日志 中继日志 事务日志 说明: 支持本文实验使用的linux系统是CentOS7版本,使用的数据库是base源自带的Mar ...

  2. 线上阿里云mysql慢_MySQL · 案例分析 · RDS MySQL线上实例insert慢常见原因分析-阿里云开发者社区...

    概述 insert慢是经常被问到的问题,笔者尝试在本文中对这个问题做一个分类梳理,列举的线上例子会做简化,希望对读者有所启发. 注意:因为阿里云MySQL线上实例还是以RDS 5.6为主体,本文的分析 ...

  3. 获取阿里云mysql实例名称_阿里云如何获取数据库名字

    全网最新活动请看下方内容或右侧内容! --------------- 阿里云如何获取数据库名字,阿里云服务器回滚数据库. 对于大多数小型或初期项目来说,我们可能常用的做法是先将web.数据库全部安装在 ...

  4. 连接并配置好无极网络VPS主机 | 配置Mysql数据库 | Centos 常用操作| vim操作 | 保持centos的任务 | 阿里云mysql | Node.js | 腾讯云mysql

    在无极网络获得主机并用Xshell6连接上 配置主机的DNS和网络连接 # http://www.5jwl.com/style/info/shownews.asp?id=1383 Xshell 6 ( ...

  5. mysql存储业务日志_MySQL 日志管理

    一.MySQL 日志 日志是mysql数据库的重要组成部分.日志文件中记录着mysql数据库运行期间发生的变化:也就是说用来记录mysql数据库的客户端连接状况.SQL语句的执行情况和错误信息等.当数 ...

  6. mysql 客户端连接日志_MySQL 日志详解

    一.MySQL 日志分类 MySQL 日志主要包含:错误日志.查询日志.慢查询日志.事务日志.二进制日志. 错误日志: -log-err (记录启动.运行.停止 MySQL 服务时出现的信息) 查询日 ...

  7. 腾讯云 mysql 远程_腾讯云服务器 MySQL 远程连接设置

    问题说明 使用 MySQL GUI 连接腾讯云的 MySQL 服务器连接失败,经查是由三个原因引起的: 云服务器未配置安全组,开通 3306 端口. 数据库默认只允许本地连接,拒绝远程连接. 所使用 ...

  8. 阿里云 mysql 超时_mysql数据库超时

    mysql数据库超时 云服务器(Elastic Compute Service,简称ECS)是阿里云提供的性能卓越.稳定可靠.弹性扩展的IaaS(Infrastructure as a Service ...

  9. 阿里云 mysql教程_mysql数据库菜鸟教程

    mysql数据库菜鸟教程 云服务器(Elastic Compute Service,简称ECS)是阿里云提供的性能卓越.稳定可靠.弹性扩展的IaaS(Infrastructure as a Servi ...

最新文章

  1. 多任务上实现SOTA,UBC、谷歌联合Hinton等提出3D点云的无监督胶囊网络
  2. 比亚迪f3android系统,比亚迪F3发动机防盗系统设定
  3. chrome 禁用恢复页面提示_有哪些很值得推荐的Chrome插件?精选7款实用插件
  4. React中props与state的区别
  5. CodeForces - 1307D Cow and Fields(最短路+思维)
  6. HH SaaS电商系统的商品营销标签功能模块设计
  7. windows和linux允许分片,请问hadoop的hdfs文件系统和本地windows文件系统或linux文件系统是什么关系啊,谢谢...
  8. php rest api lumen,使用Lumen框架创建 REST API 实例教程
  9. Myeclipse包变成文件夹
  10. 关于大数据和互联网的一点想法
  11. 【李宏毅2020 ML/DL】P67-72 Anomaly Detection
  12. linux yum未找到命令,解决yum命令失效,vim: command not found
  13. oracle中with子句的用法(转)
  14. 查看win10的产品密钥过期时间
  15. 什么软件测试情侣头像,情侣头像另一半怎么找,请问什么软件可以找出
  16. 仿9GAG制作过程(一)
  17. 使用python embedded distribution
  18. cannot access memory
  19. 神码ai人工智能写作机器人_AI启动协变量AI为机器人构建通用AI
  20. flutter显示图标_flutter 引入第三方 Icon 图标(以阿里图标库为例)

热门文章

  1. why context node binding does not work in pop up window case
  2. SAP OData执行的后台跟踪工具
  3. bInitiallyDisabled
  4. java机试 数据结构_来看看阿里面试的一面都面了些什么笔试+机试(java岗)
  5. ppp协议pap验证过程状态转移图_电脑网络知识:TCP协议的高级特性,你所不知道的TCP...
  6. 删除有序数组中的重复项 IIPython解法
  7. 使用 stm32实现锂电充电_实现高负载锂电池的超快速充电需要哪些要求?
  8. 自动化html定位,Selenium自动化定位方法
  9. java写入txt文件 不替换_java非覆盖写入文件及在输出文本中换行
  10. ct报告就一定准确吗_晋州市人民医院检验报告出具时间提速啦!