数据库单,多,全库、冷热备份思路及备份与还原(mysqldump)

热备份:服务开启状态下进行备份,
冷备份:服务关闭状态进行备份,
冷备份
数据库原有内容如下:
MariaDB [(none)]> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| 学员名单 |
| auth |
| mydb |
| mysql |
| performance_schema |
| shuifei |
| test |
| yg |
+--------------------+
9 rows in set (0.00 sec)
要求备份数据库目录并删除shuifei数据库最后完成还原shuifei
1:直接打包数据库文件夹
[root@localhost ~]# systemctl stop mariadb #关闭mysql服务进行备份
[root@localhost ~]# mkdir backup
tar: 从成员名中删除开头的“/”
[root@localhost ~]# tar Jcf backup/mysql_all-$(date +%F).tar.xz /var/lib/mysql/
tar: /var/lib/mysql/mysql.sock: 忽略套接字(socket)
[root@localhost ~]# ls backup/
mysql_all-2019-10-14.tar.xz
2:删除shuifei数据并开启mariadb服务
[root@localhost ~]# rm -rf /var/lib/mysql/shuifei/
[root@localhost ~]# systemctl start mariadb
MariaDB [(none)]> show databases; #查看所有数据库此时shuifei数据库已经消失
+--------------------+
| Database |
+--------------------+
| information_schema |
| 学员名单 |
| auth |
| mydb |
| mysql |
| performance_schema |
| test |
| yg |
+--------------------+
8 rows in set (0.00 sec)
2:进行备份shuifei到数据库目录下
[root@localhost ~]# mkdir restore
[root@localhost ~]# tar xf backup/mysql_all-2019-10-14.tar.xz -C restore/
[root@localhost mysql]# mv shuifei/ /var/lib/mysql/
MariaDB [(none)]> show databases;
+--------------------+
| Database |
+--------------------+
| information_schema |
| shuifei |
| yg |
+--------------------+
9 rows in set (0.00 sec)
热备份
第二种:使用专用备份工具mysqldump

对单个库进行完全备份:
格式:mysqldump -u 用户名 -p密码 --databases 库名 > /备份路径/备份文件名
[root@localhost ~]# mysqldump -uroot -p123123 --databases shuifei > backup/shuifei-$(date +%Y%m%d).sql
[root@localhost backup]# ls
mysql_all-2019-10-14.tar.xz shuifei-20191014.sql
对多个库进行完全备份:
格式:mysqldump -u 用户名 -p密码 --databases 库名1 库名2 > /备份路径/备份文件名
[root@localhost ~]# mysqldump -uroot -p123123 --databases shuifei mydb > backup/shuifei+mydb-$(date +%Y%m%d).sql
[root@localhost ~]# cd backup/
[root@localhost backup]# ls
mysql_all-2019-10-14.tar.xz shuifei-20191014.sql shuifei+mydb-20191014.sql
[root@localhost backup]#
第三种:对所有库进行完全备份:
格式:mysqldump -u用户名 -p密码 --event --opt --all-databases > /备份路径/备份文件名
[root@localhost backup]# mysqldump -uroot -p123123 --event --opt --all-databases > backup/mysql_all.$(date +%Y%m%d).sql
[root@localhost backup]# ls
mysql_all.20191014.sql mysql_all-2019-10-14.tar.xz shuifei-20191014.sql shuifei+mydb-20191014.sql
第四种:对表进行备份:
格式:mysqldump -u用户名 -p密码 -d 数据库名 表名> /备份路径/备份文件名
[root@localhost ~]# mysqldump -uroot -p123123 -d shuifei shuifei_info > backup/desc-$(date +%Y%m%d).sql
[root@localhost ~]# cd backup/
[root@localhost backup]# ls
desc-20191014.sql mysql_all-2019-10-14.tar.xz shuifei+mydb-20191014.sql
mysql_all.20191014.sql shuifei-20191014.sql
使用mysqldump备份后,恢复数据库:
方法1:source命令
登入到MYSQL数据库后,执行source备份脚本路径
删除yg和shuifei两个数据库
MariaDB [yg]> drop database yg;
MariaDB [yg]> drop database shuifei;
恢复yg和shuifei两个数据库:
MariaDB [yg]> source backup/shuifei-20191014.sql
MariaDB [mysql]> source backup/yg-20191014.sql
第二种方法:mysql命令:
格式:mysql -u 用户名 -p密码 < 库备份脚本路径
MariaDB [shuifei]> drop database yg;
Query OK, 1 row affected (0.00 sec)
[root@localhost ~]# mysql -uroot -p123123 < backup/yg-20191014.sql
[root@localhost ~]# mysql -uroot -p123123 -e 'show databases' #-e表示可以在外部执行mysql语句
+--------------------+
| Database |
+--------------------+
| information_schema |
| mysql |
| shuifei |
| yg |
+--------------------+
数据库单,多,全库、冷热备份思路及备份与还原(mysqldump)的更多相关文章
- 通过Xtrabackup实现MySQL实例的全库备份与按需单库恢复
在实际的生产环境中,为了管理方便,我们一般是通过 Xtrabackup实现实例的全库备份,即将实例上的所有数据库备份. 但是,考虑到快速恢复 我们常常面临的需求是快速还原单个数据库.针对初学者来说,网 ...
- Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份)
原文地址:http://www.tuicool.com/articles/RZRnq2 Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对In ...
- MySQL 採用Xtrabackup对数据库进行全库备份
1,xtrabackup简单介绍 关于数据库备份以及备份工具.參考:http://blog.itpub.net/26230597/viewspace-1460065/,这里来介绍xtrabackup已 ...
- MySQL用全库备份数据恢复单表数据
备份数据库时,采用了全库备份,但是因为某些原因需要回滚一个表的数据到备份数据库上,如果回滚整个库就比较费时间,因为可能这个表只有几十M,但是其它表可能有十几上百G,这时候就需要将需要恢复的表提取出来了 ...
- Percona备份mysql全库及指定数据库(完整备份与增量备份)
Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份) Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对I ...
- MySQL 采用Xtrabackup对数据库进行全库备份
1,xtrabackup简介 关于数据库备份以及备份工具,参考:http://blog.itpub.net/26230597/viewspace-1460065/,这里来介绍xtrabackup已经如 ...
- LINUX学习笔记——LINUX下EXP命令全库备份数据库文件
LINUX下EXP命令全库备份数据库文件 1)建立备份目录,目录操作权限授权给Oracle用户 mkdir /backup --创建backup文件夹 cd / --进入cd语句 ls -l ...
- Mysql数据库定时全库备份
如下脚本用于mysql全库定时备份 mysql_dump_script.sh #!/bin/bash #保存备份个数,最多保留4个文件 number=4 #备份保存路径 backup_dir=/db/ ...
- 使用mysql自带工具mysqldump进行全库备份以及source命令恢复数据库
mysql数据库提供了一个很好用的工具mysqldump用以备份数据库,下面将使用mysqldump命令进行备份所有数据库以及指定数据库 一.mysqldump一次性备份所有数据库数据 /usr/lo ...
随机推荐
- [CF]Round513
A Phone Numbers 题意:定义"电话号码"为开头为'8',长度为11的字符串.给定一些字符,每个字符只能用一次,求可以拼出多少个电话号码(可以重复). 直接min(st ...
- js -- 高阶函数的使用
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...
- java多线程--死锁
1. Java中导致死锁的原因 Java中死锁最简单的情况是,一个线程T1持有锁L1并且申请获得锁L2,而另一个线程T2持有锁L2并且申请获得锁L1,因为默认的锁申请操作都是阻塞的,所以线程T1和T2 ...
- <context:component-scan>标签
在spring-mvc的配置文件Springmvc-servlet.xml中,要扫描Controller注解的类,用<context:include-filter>标签 <conte ...
- mybatis(六):设计模式 - 单例模式
- DVWA全级别之XSS(Reflected)、XSS(Stored)【跨站脚本攻击】
XSS XSS,全称Cross Site Scripting,即跨站脚本攻击,某种意义上也是一种注入攻击,是指攻击者在页面中注入恶意的脚本代码,当受害者访问该页面时,恶意代码会在其浏览器上执行,需要强 ...
- 故障解决 | win10没声音及找不到Realtek高清音频管理器
重装 win10 系统后,电脑没声音,更新驱动以及万不得已下载驱动精灵都没有解决. 后来发现在“硬件和声音”中没有Realtek高清音频管理器,之后找到解决办法如下: 1. 找到Realtek高清音频 ...
- ansible笔记(2):管理清单配置详解
前情提要:管理清单(Iventory)配置文件/etc/ansible/hosts.通过修改该配置文件以达到管理受控主机的目的. 在我的实验平台上有3台主机:192.168.232.181(an ...
- SAIF anno
https://www.cnblogs.com/IClearner/p/6898463.html SAIF--RTL BACK分析法 RTL backward SAIF文件是通过对RTL代码进行仿真得 ...
- arcgis计算X坐标值、Y坐标值
arcgis计算X坐标值.Y坐标值 要计算的字段上点击右键,选择计算几何,弹出计算几何对话框.可以设置属性.坐标系.单位等.