MySQL中的日志管理 日志备份与恢复(一)

本文涉及的产品
云数据库 RDS MySQL,集群版 2核4GB 100GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用版 2核4GB 50GB
简介: MySQL中的日志管理 日志备份与恢复(一)

MySQL日志管理

MySQL的默认日志保存位置为/usr/local/mysql/data


日志开启方式有两种:通过配置文件或者是通过命令

通过命令修改开启的日志是临时的,关闭或重启服务后就会关闭


一、MySQL常用日志类型及开启


vim /etc/my.cnf
[mysqld]
......

1、错误日志

用来记录当MySQL启动、停止或运行时发生的错误信息,默认已开启

指定日志的保存位置和文件名
log-error=/usr/local/mysql/data/mysql_error.log

2、通用查询日志

用来记录MySQL的所有连接和语句,默认是关闭的

general_log=ON
general_log_file=/usr/local/mysql/data/mysql_general.log

3、二进制日志(binlog)

用来记录所有当MySQL启动、停止或运行时发送的错误信息,默认是关闭的

log-bin=mysql-bin    
log_bin=mysql-bin

4、慢查询日志

用来记录所有执行时间超过long_query_time秒的语句,可以找到哪些查询语句执行时间长,以便于优化,默认是关闭的

slow_query_log=ON
slow_query_log_file=/usr/local/mysql/data/mysql_slow_query.log
long_query_time=5      
systemctl restart mysqld



二、查看日志状态


1、查看通用查询日志是否开启

mysql -u root -p
show variables like 'general%';

2、查看二进制日志是否开启

show variables like 'log_bin%';

3、查看慢查询日功能是否开启

show variables like '%slow%';

查看慢查询时间设置

show variables like 'long_query_time';

在数据库中设置开启慢查询的方法

set global slow_query_log=ON;
该方法重启服务失效



MySQL备份与恢复


一、数据备份的重要性



备份的主要目的是灾难恢复

在生产环境中,数据的安全性至关重要

任何数据的丢失都可能产生严重的后果


造成数据丢失的原因

1、程序错误

2、人为操作错误

3、运算错误

4、磁盘故障

5、灾难(火灾、地震、盗窃等)


二、数据库备份的分类


1、从物理与逻辑的角度,备份可分为

1、物理备份:对数据库操作系统的物理文件(如数据文件、日志文件等)的备份


物理备份方法:

1.冷备份(脱机备份):是在关闭数据库的时候进行的

2.热备份(联机备份):数据库处于运行状态,依赖于数据库的日志文件

3.温备份:数据库锁定表格(不可写入但可读)的状态下进行备份操作


2、逻辑备份:对数据库逻辑组件(如:表等数据库对象)的备份


2、从数据库的备份策略角度,备份可分为

1、完全备份:每次对数据库进行完整的备份


完全备份是对整个数据库、数据库结构和文件结构的备份。

保存的是备份完成时刻的数据库。

是差异备份与增量备份的基础。

相当于基石。


2、差异备份:备份自从上次完全备份之后被修改过的文件


3、增量备份:只要在上次完全备份或者增量备份后被修改的文件才会被备份


三、常见的备份方法


1、物理冷备

备份时数据库处于关闭状态,直接打包数据库文件

备份速度快,恢复时也是最简单的

关闭MySQL数据库

使用tar命令直接打包数据库文件夹

直接替换现有的MySQL目录即可


2、专用备份工具mydump或者mysqlhotcopy

mysqldump常用的逻辑备份工具

MySQL自带的备份工具,可实现对MySQL的备份

可以将指定的库、表导出为SQL脚本

使用命令mysql导入备份的数据


mysqlhotcopy仅拥有备份myisam和archive表


3、启动二进制日志进行增量备份

进行增量备份,需要刷新二进制日志


4、第三方工具备份

免费的MySQL热备份软件Percona XtraBackup

相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
17天前
|
存储 关系型数据库 MySQL
|
17天前
|
存储 SQL 关系型数据库
|
3天前
|
监控
查看服务器/IIS日志、log、访问信息基本方法
除了手动查看,你也可以使用日志分析工具,如Log Parser、AWStats等,这些工具可以帮助你更方便地分析日志数据。
4 1
|
11天前
|
Java 测试技术 Apache
《手把手教你》系列基础篇(八十六)-java+ selenium自动化测试-框架设计基础-Log4j实现日志输出(详解教程)
【7月更文挑战第4天】Apache Log4j 是一个广泛使用的 Java 日志框架,它允许开发者控制日志信息的输出目的地、格式和级别。Log4j 包含三个主要组件:Loggers(记录器)负责生成日志信息,Appenders(输出源)确定日志输出的位置(如控制台、文件、数据库等),而 Layouts(布局)则控制日志信息的格式。通过配置 Log4j,可以灵活地定制日志记录行为。
27 4
|
12天前
|
SQL 安全 关系型数据库
MySQL的binlog日志的简介与查看
MySQL的binlog日志的简介与查看
26 4
|
12天前
|
运维 Java Apache
Java中的日志框架:Log4j与SLF4J详解
Java中的日志框架:Log4j与SLF4J详解
|
13天前
|
关系型数据库 MySQL 数据库
MySQL 启动日志报错: File /mysql-bin.index not found (Errcode: 13 - Permission denied)
MySQL 启动日志报错: File /mysql-bin.index not found (Errcode: 13 - Permission denied)
31 2
|
14天前
|
存储 关系型数据库 MySQL
|
9天前
|
XML Java 测试技术
《手把手教你》系列基础篇(八十八)-java+ selenium自动化测试-框架设计基础-Log4j 2实现日志输出-下篇(详解教程)
【7月更文挑战第6天】本文介绍了如何使用Log4j2将日志输出到文件中,重点在于配置文件的结构和作用。配置文件包含两个主要部分:`appenders`和`loggers`。`appenders`定义了日志输出的目标,如控制台(Console)或其他文件,如RollingFile,设置输出格式和策略。`loggers`定义了日志记录器,通过`name`属性关联到特定的类或包,并通过`appender-ref`引用`appenders`来指定输出位置。`additivity`属性控制是否继承父logger的配置。
15 0
|
9天前
|
JSON 应用服务中间件 开发工具
Ngnix的http块自定义服务日志,access.log和error.log,log_format指定日志输出格式设置
Ngnix的http块自定义服务日志,access.log和error.log,log_format指定日志输出格式设置