热备份:服务开启状态下进行备份,

冷备份:服务关闭状态进行备份,

冷备份

数据库原有内容如下:

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)的更多相关文章

  1. 通过Xtrabackup实现MySQL实例的全库备份与按需单库恢复

    在实际的生产环境中,为了管理方便,我们一般是通过 Xtrabackup实现实例的全库备份,即将实例上的所有数据库备份. 但是,考虑到快速恢复 我们常常面临的需求是快速还原单个数据库.针对初学者来说,网 ...

  2. Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份)

    原文地址:http://www.tuicool.com/articles/RZRnq2 Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对In ...

  3. MySQL 採用Xtrabackup对数据库进行全库备份

    1,xtrabackup简单介绍 关于数据库备份以及备份工具.參考:http://blog.itpub.net/26230597/viewspace-1460065/,这里来介绍xtrabackup已 ...

  4. MySQL用全库备份数据恢复单表数据

    备份数据库时,采用了全库备份,但是因为某些原因需要回滚一个表的数据到备份数据库上,如果回滚整个库就比较费时间,因为可能这个表只有几十M,但是其它表可能有十几上百G,这时候就需要将需要恢复的表提取出来了 ...

  5. Percona备份mysql全库及指定数据库(完整备份与增量备份)

    Percona Xtrabackup备份mysql全库及指定数据库(完整备份与增量备份) Xtrabackup简介 Percona XtraBackup是开源免费的MySQL数据库热备份软件,它能对I ...

  6. MySQL 采用Xtrabackup对数据库进行全库备份

    1,xtrabackup简介 关于数据库备份以及备份工具,参考:http://blog.itpub.net/26230597/viewspace-1460065/,这里来介绍xtrabackup已经如 ...

  7. LINUX学习笔记——LINUX下EXP命令全库备份数据库文件

    LINUX下EXP命令全库备份数据库文件 1)建立备份目录,目录操作权限授权给Oracle用户 mkdir /backup  --创建backup文件夹 cd  /   --进入cd语句 ls  -l ...

  8. Mysql数据库定时全库备份

    如下脚本用于mysql全库定时备份 mysql_dump_script.sh #!/bin/bash #保存备份个数,最多保留4个文件 number=4 #备份保存路径 backup_dir=/db/ ...

  9. 使用mysql自带工具mysqldump进行全库备份以及source命令恢复数据库

    mysql数据库提供了一个很好用的工具mysqldump用以备份数据库,下面将使用mysqldump命令进行备份所有数据库以及指定数据库 一.mysqldump一次性备份所有数据库数据 /usr/lo ...

随机推荐

  1. ubuntu19.04 配置远程连接ssh

    安装ssh-server sudo apt install openssh-server 参照:https://baijiahao.baidu.com/s?id=1631505486531979316 ...

  2. 执行yum相关命令总是卡住,ctrl+c也退出不了

    问题描述 在用yum.rpm命令安装或查询任何包时,执行相关命令后无任何反应,直接卡住,也未给出任何错误提示信息,ctrl+c也不好使,只能杀掉进程. 原因 出现此问题是因为rpm的数据库出现异常了, ...

  3. JQ DOM元素 创建 添加 删除

    创建元素 // 创建元素节点 $('<p></p>'); // 创建属性节点 $('<p class="wow"></p>'); / ...

  4. bugku 有一张图,还单纯吗

    下载图片后以多种方式打开.分析文件类型都没能找到flag.推测存在隐藏文件,即文件可分离. 注:文件分离需要 binwalk 工具,在Ubuntu操作系统下 binwalk 的安装方法可参考此博客:h ...

  5. Intellij-Idea使用小细节

    SpringMVC项目部署到tomcat中文乱码,tomcat的配置里面加上 -Dfile.encoding=UTF-8

  6. Flink流处理(五)- 状态与一致性模型

    状态(State)与一致性模型 接下来我们转向另一个在流处理中十分重要的点:状态(state).状态在数据处理中是无处不在的.为了产生一个结果,函数一般会聚合某个时间段内(或是一定数量的)events ...

  7. 6.springboot----------JSR303校验

    JSR303校验(Java Specification Requests的缩写,意思是Java 规范提案) 有一个注解叫:@Validated  //数据校验 这是默认的↓ 这是你可以改的↓

  8. dea创建Maven工程用c3p0连接数据库报错java.sql.SQLException: Connections could not be acquired from the underlying

    idea   java.sql.SQLException: Connections could not be acquired from the underlying database! 转载自:ht ...

  9. STL之pair类型

    C++ pair 类型 ---心怀虔诚,细细欣赏! 编程实践: Practice:编写程序读入一系列string和int型数据,将每一组存储在一个pair对象中,然后将这些pair对象存储在vecto ...

  10. STA之PVT

    在STA星球,用library PVT.RC corner跟OCV来模拟这些不可控的随机因素.在每个工艺结点,通过大量的建模跟实测,针对每个具体的工艺,foundary厂都会提供一张推荐的timing ...