MySQL 日志管理、备份与恢复

MySQL 日志管理、备份与恢复

一、MySQL日志管理

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

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

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

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

vim /etc/my.cnf

指定日志的保存位置和文件名

log-error=/usr/local/mysql/data/mysql_error.log					

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

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

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

在这里插入图片描述

systemctl restart mysqld    

2、查看日志状态

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

show variables like 'general%';	

在这里插入图片描述

查看二进制日志是否开启
show variables like 'log_bin%';
在这里插入图片描述

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

show variables like '%slow%';	

在这里插入图片描述

查看慢查询时间设置

show variables like 'long_query_time';

在这里插入图片描述

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

set global slow_query_log=ON;

该方法重启服务失效

二、MySQL备份与恢复

1、数据备份的重要性

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

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

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

造成数据丢失的原因
程序错误
人为操作错误
运算错误
磁盘故障
灾难 (如火灾、地震) 和盗窃

2、数据库备份的分类

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

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

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

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

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

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

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

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

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

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

(三)、常见的备份方法
1、物理冷备

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

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

2、专用备份工具 mydump 或 mysqlhotcopy

mysqldump 常用的逻辑备份工具

mysqlhotcopy 仅拥有备份 MyISAM 和 ARCHIVE 表

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

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

4、第三方工具备份

免费的MySQL 热备份软件 Percona XtraBackup

3、MySQL完全备份

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

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

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

1、优点:
备份与恢复操作简单方便

2、缺点:
数据存在大量的重复

占用大量的备份空间

备份与恢复时间长

create database SCHOOL;
use SCHOOL;
create table if not exists CLASS1 (
id int(4) not null auto_increment,
name varchar(10) not null,
sex char(10) not null,
hobby varchar(50),
primary key (id));

insert into CLASS1 values(1,'user1','male','running');
insert into CLASS1 values(2,'user2','female','singing');

set password = password('abc123');

在这里插入图片描述

物理冷备份与恢复

systemctl stop mysqld
yum -y install xz

压缩备份

tar Jcvf /opt/mysql_all_$(date +%F).tar.xz /usr/local/mysql/data/

解压恢复

tar Jxvf /opt/mysql_all_2020-11-22.tar.xz -C /usr/local/mysql/data

systemctl restart mysql

mysqldump 备份与恢复

mysqldump -u root -p[密码] --databases 库名1 [库名2] … > /备份路径/备份文件名.sql #导出的就是数据库脚本文件

mysqldump -u root -pabc123 --databases SCHOOL > /opt/SCHOOL.sql
mysqldump -u root -pabc123 --databases mysql SCHOOL > /opt/mysql-SCHOOL.sql

2)完全备份 MySQL 服务器中所有的库

mysqldump -u root -p[密码] --all-databases > /备份路径/备份文件名.sql

mysqldump -u root -p123123 --all-databases > /opt/all.sql

3)完全备份指定库中的部分表

mysqldump -u root -p[密码] 库名 [表名1] [表名2] … > /备份路径/备份文件名.sql

mysqldump -uroot -pabc123 SCHOOL CLASS1 > 	/opt/SCHOOL_CLASS1.sql
#使用“-d”选项,说明只保存数据库的表结构
#不使用“-d”选项,说明表数据也进行备份

4)查看备份文件

grep -v "^--" /opt/SCHOOL_CLASS1.sql | grep -v "^/" | grep -v "^$"

完全备份恢复

1、恢复数据库

mysql -uroot -pabc123 -e 'drop database SCHOOL;'

mysql -uroot -pabc123 -e 'SHOW DATABASES;'

mysql -uroot -pabc123 < /opt/SCHOOL.sql
mysql -uroot -pabc123 -e 'SHOW DATABASES;'

2、恢复数据表

mysql -uroot -pabc123 -e 'drop table SCHOOL.CLASS1;'
mysql -uroot -pabc123 -e 'show tables from SCHOOL;'

mysql -uroot -pabc123SCHOOL < /opt/SCHOOL_CLASS1.sql
mysql -uroot -pabc123 -e 'show tables from SCHOOL;'

猜你喜欢

转载自blog.csdn.net/weixin_44505291/article/details/113698731