使用LVM备份和还原Mariadb数据库

通过和mysqldump进行对比介绍LVM快照卷

Mysqldump:无法进行热备份,数据库较大时备份时间较长,优点就是备份恢复非常的简单。

LVM优缺点如下:

优点:

1、几乎热备,只是在备份的时候为了方式产生数据不一致问题,需要锁定数据库。

2、支持所有存储引擎,因为LVM备份的原理只是拷贝文件

3、备份和恢复速度块,因为备份和恢复的原理只是拷贝文件。

缺点:

1、数据库必须放在LVM逻辑卷上

2、如果是生产环境有用户启动了事务,那么锁定数据库的过程可能需要很长的时间,而且也无法准确获得数据库停止时间

使用快照卷备份Mariadb

备份的前提条件:mysql的数据必须放在LVS逻辑卷之上,否则无法实现LVS备份。

如果使用LVS对单个数据库进行备份的话,需要使用innodb存储引擎,因为innodb存储引擎是每表一个表文件。

MariaDB[(none)]> SHOW GLOBAL VARIABLES LIKE ‘innodb_file_%‘;
+--------------------------+----------+
|Variable_name            | Value    |
+--------------------------+----------+
|innodb_file_format       | Antelope |
|innodb_file_format_check | ON       |
|innodb_file_format_max   | Antelope |
|innodb_file_per_table    | ON       |
+--------------------------+----------+

备份六步走:

1、请求锁定所有表:

主要是为了防止在备份过程中有用户修改数据,造成备份和原数据的不一致性,需要在备份之前锁定表,防止用户修改,备份完成之后在解锁。

MariaDB[(none)]> FLUSH TABLES WITH READ LOCK;

说明:如果是生产环境有用户启动了事务,那么锁定数据库的过程可能需要很长的时间。

2、记录二进制日志文件及事件位置:

备份完成之后滚动日志,然后记录日志文件的位置,

MariaDB [(none)]> flush logs;
MariaDB [(none)]> show master status;
+------------------+----------+--------------+------------------+
| File            | Position | Binlog_Do_DB | Binlog_Ignore_DB |
+------------------+----------+--------------+------------------+
| mysql-bin.000002 |      245 |              |                  |
+------------------+----------+--------------+------------------+
1 row in set (0.00 sec)

3、创建快照:

创建快照卷,这里使用的是额外启动的终端,因为数据库一旦退出,锁就释放了。

[[email protected] ~]# lvcreate -L 200M -n mydata-snap-s -p r /dev/myvg/mydata

4、释放锁:

MariaDB[(none)]> UNLOCK TABLES;

5、挂载快照卷,复制数据进行备份;

挂载快照卷

[[email protected] ~]# mkdir /snap
[[email protected] ~]# mount /dev/myvg/mydata-snap/snap/
[[email protected] ~]# ls /snap/data/
aria_log.00000001 ibdata1      Mariadb.err  mysql-bin.000001  performance_schema
aria_log_control   ib_logfile0 Mariadb.pid  mysql-bin.000002  test
hellodb           ib_logfile1  mysql        mysql-bin.index

复制数据进行备份

只是备份单个库使用

[[email protected] ~]# rsync -a /snap/data/hellodb//backup/hellodb-`date +%F-%H-%M-%S`
[[email protected] ~]# ls /backup/hellodb-2015-05-28-02-57-12/hellodb/
classes.frm coc.MYD      courses.MYI  scores.MYI   tb1.frm       toc.frm
classes.MYD coc.MYI      db.opt       students.frm  teachers.frm toc.MYD
classes.MYI courses.frm  scores.frm   students.MYD teachers.MYD  toc.MYI
coc.frm     courses.MYD  scores.MYD   students.MYI teachers.MYI

备份整个库

[[email protected] ~]# rsync -a /snap/data/*/backup/mariadb-all-`date +%F-%H-%M-%S`
[[email protected] ~]# ls/backup/mariadb-all-2015-05-28-02-57-51/
aria_log.00000001 ibdata1      Mariadb.err  mysql-bin.000001  performance_schema
aria_log_control  ib_logfile0  Mariadb.pid  mysql-bin.000002  test
hellodb           ib_logfile1  mysql        mysql-bin.index

6、备份完成之后,删除快照卷;

[[email protected] ~]# umount /snap/
[[email protected] ~]# lvremove /dev/myvg/mydata-snap
Do you really want to remove active logical volumemydata-snap? [y/n]: y

模拟误删除

备份完成之后修改了一些数据

MariaDB [hellodb]> drop table tb1;
MariaDB [hellodb]> create table tb2 (id int);
MariaDB [hellodb]> insert into tb2 values(1),(2),(3);
MariaDB [hellodb]> select * from tb2;
+------+
| id   |
+------+
|    1 |
|    2 |
|    3 |
+------+

3 rows in set (0.00 sec)

修改完成之后把hellodb数据库误删除了

MariaDB [hellodb]> drop database hellodb;

然后还把整个数据库误删除了(说明:如果是生产环境二进制日志文件和数据文件一定是分开存放的,但是实验安装时如果是二进制日志文件和数据目录在一起,应该先复制一份二进制日志文件到备份目录)

[[email protected] ~]# rm -rf/mydata/data/*

数据库故障恢复

Mysql出现大故障时,最好停掉数据库,如果无法停止就杀死进程

[[email protected] ~]# service mysqld stop
MySQL server PID file could not be found!                  [FAILED]
[[email protected] ~]# killall mysqld
mysqld: no process killed

从二进制日志文件中导出所有和hellodb数据库相关的操作。

导出之前需要去掉误删除语句,查看语句在二进制日志文件中的记录位置

MariaDB [(none)]> show binlog events in‘mysql-bin.000002‘\G;
*************************** 7. row***************************
   Log_name:mysql-bin.000003
        Pos:642
 Event_type:Query
  Server_id:1
End_log_pos: 729
       Info:drop database hellodb
7 rows in set (0.00 sec)

得到语句记录位置之后,不导出记录删除位置

[[email protected] ~]# mysqlbinlog --stop-position=729/mydata/data/mysql-bin.000002 > /backup/lvm.sql

复制所有备份的文件和目录到数据目录下

[[email protected] ~]# cp -a /backup/mariadb-all-2015-05-28-02-57-51/*/mydata/data/
[[email protected] ~]# ll /mydata/data/
total 28764
-rw-rw---- 1 mysql mysql    16384 May 27 22:30 aria_log.00000001
-rw-rw---- 1 mysql mysql       52 May 27 22:30 aria_log_control
drwx------ 2 mysql mysql     4096 May 28 00:49 hellodb
-rw-rw---- 1 mysql mysql 18874368 May 28 00:49ibdata1
-rw-rw---- 1 mysql mysql  5242880 May 28 00:49 ib_logfile0
-rw-rw---- 1 mysql mysql  5242880 May 27 22:34 ib_logfile1
-rw-r----- 1 mysql root      5674 May 28 00:43 MariaDB.err
-rw-rw---- 1 mysql mysql        5May 28 00:43 MariaDB.pid
drwx------ 2 mysql root      4096 May 27 22:30 mysql
-rw-rw---- 1 mysql mysql      632 May 27 23:12 mysql-bin.000001
-rw-rw---- 1 mysql mysql     8667 May 27 23:22 mysql-bin.000002
-rw-rw---- 1 mysql mysql      114 May 28 00:50 mysql-bin.index
drwx------ 2 mysql mysql     4096 May 27 22:30 performance_schema
drwx------ 2 mysql root      4096 May 27 22:30 test

这个时候启动mysqld服务就可以看到备份之前的数据了

[[email protected] ~]# mysql -u root -p
MariaDB [(none)]> use hellodb;
MariaDB [hellodb]> show tables;
+-------------------+
| Tables_in_hellodb |
+-------------------+
| classes          |
| coc              |
| courses          |
| scores           |
| students         |
| tb1              |
| teachers         |
| toc              |
+-------------------+
MariaDB [hellodb]> select * from tb1;
+------+
| id   |
+------+
|    1 |
|    2 |
|    3 |
|   21 |
|   22 |
|   23 |
+------+
6 rows in set (0.01 sec)

恢复的数据只是备份之前的数据,备份之后更改的数据还没有回了,这个时候就需要导入二进制日志转换成的sql文件了

[[email protected] ~]# mysql -u root -p </backup/lvm.sql

查看数据就可以看到tb2了

MariaDB [hellodb]> show tables;
+-------------------+
| Tables_in_hellodb |
+-------------------+
| classes          |
| coc              |
| courses          |
| scores           |
| students         |
| tb2               |
| teachers         |
| toc              |
+-------------------+
MariaDB [hellodb]> select * from tb2;
+------+
| id   |
+------+
|    1 |
|    2 |
|    3 |
+------+
时间: 2024-08-02 19:43:30

使用LVM备份和还原Mariadb数据库的相关文章

如何备份和还原sqlite数据库

Backing up the database To make a backup copy of the database, simply do a "dump" and redirect the results to a file. cd /home/sqlite sqlite3 sample.db .dump > sample.bak Restoring the database Restoring the database from a backup is just as

如何使用命令来备份和还原MySQL数据库

数据库在使用当中都会有数据库备份工作,当数据库发生严重错误无法启动,或者数据丢失时可以及时有效地恢复数据.那么多备份就简单介绍如何使用命令来备份和还原MySQL数据库. 备份数据库 使用mysqldump命令备份数据库 代码如下: # 如果要将game数据库进行备份: mysqldump -u root -p game > game_backup.sql # 如果希望备份所有的数据库: mysqldump -u root -p --all-databases > all_backup.sql

使用lvm 备份和恢复mysql数据库

案列中查询用到的命令: show engines;   ---现在已提供什么存储引擎 show variables like '%storage_engine%';  -----当前默认的存储引擎 设置InnoDB为默认引擎:在配置文件my.cnf中的 [mysqld] 下面加入default-storage-engine=INNODB 一句,也可以再加上  innodb_file_per_table=1  #让innodb的每个表文件单独存储 show master status ;  --查

SQL Server之备份和还原系统数据库

系统数据库是管理和维护SQL Server所必须的数据库,对服务器实例的运行至关重要.每次进行大量更新后必须备份多个系统数据库,包括master.model.msdb,备份这些系统数据库,就可以在发生系统故障(如硬盘丢失)时还原和恢复SQL Server系统 需要备份的系统数据库 1. 备份系统数据库 2. 模拟数据库损坏 (1)首先,停止SQL Server服务 (2)然后,删除系统数据库文件 (3)再次开启SQL Server服务,发现系统报错,SQL Server数据库系统瘫痪 3. 现在

备份与还原mysql 数据库的常用命令。

一.备份数据: Mysqldump常用命令: mysqldump -u用户名 -p密码 --databases 数据库1 数据库2 > xxx.sql 常见选项: -u: 用户名 -p: 密码 -P: 端口号,不写默认3306 --all-databases, -A:备份所有数据库 --databases, -B: 用于备份多个数据库,如果没有该选项,mysqldump把第一个名字参数作为数据库名,后面的作为表名.使用该选项,mysqldum把每个名字都当作为数据库名. -d: 只导出数据库的表

备份与还原mysql 数据库的常用命令

--备份数据:-- mysqldump常用命令: mysqldump -u用户名 -p密码 --databases 数据库1 数据库2 > xxx.sql 常见选项: -u: 用户名 -p: 密码 -P: 端口号,不写默认3306 --all-databases, -A:备份所有数据库 --databases, -B: 用于备份多个数据库,如果没有该选项,mysqldump把第一个名字参数作为数据库名,后面的作为表名. 使用该选项,mysqldum把每个名字都当作为数据库名. -d: 只导出数据

基于逻辑卷LVM的MySQL、mariadb数据库备份还原详细实现

前提是数据库的数据是放在逻辑卷上的: 数据库数据和日志分开存放:正常情况下数据和日志是放在两个独立的磁盘上,如果是raid的话,那么就无所谓了. 创建分区:         [[email protected] ~]$fdisk /dev/sda         Command (m for help): n         All primary partitions are in use         Adding logical partition 6         First sec

xtrabackup备份还原mariadb数据库

一.xtrabackup 简介 xtrabackup 是由percona公司开源免费的数据库热备软件,它能对InnoDB数据库和XtraDB存储引擎的数据库非阻塞地备份,对于myisam的备份同样需要加表锁.mysqldump备份方式是通过用户名密码连接到数据库,将其要备份的数据库用SQL语句的形式输出到标准输出,这种逻辑备份的方式最大的缺点是备份和恢复的速度较慢,如果数据库过大,mysqldump备份就显得力不从心了.这时选择用xtrabackup来备份就能很好解决数据库过大而导致备份过慢的问

CentOS6.5下通过Shell创建、备份、还原MySQL数据库

创建数据库: mysql -uroot -p123456 -e "CREATE DATABASE IF NOT EXISTS yourDatabaseName DEFAULT CHARSET utf8 COLLATE utf8_general_ci;" 备份数据库: mysqldump -uroot -p123456 yourDatabaseName > c:\backupFileName.dmp 还原数据库: mysql -uroot -p123456 yourDatabase