假如我们应用程序需要一台 mssql 数据库来持久化数据,我们将 mssql 数据库运行于 Docker 容器中:

docker run -d -p 1433:1433 -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<数据库SA账户的密码>" --mount type=volume,src=mssqlvol,dst=/var/opt/mssql --name mssql mcr.microsoft.com/mssq l/server

注意:-v 或者 --volume 标志适用于独立容器,--mount 标志适用于 Swarm 服务。但是在 Docker 17.06 版本之后, --mount 标志同样适用于独立容器。

执行上面的指令,如果 mssqlvol 不存在的话,会创建一个 mssqlvol 数据卷。它指向 mssql 容器的 /var/opt/mssql 目录, 此目录也是 mssql 数据库默认的数据存放目录。

备份

使用命令:

docker run --rm -volumes-from mssql --mount type=bind,src=$(pwd),dst=/backup ubuntu tar cvf /backup/backup.tar /var/opt/mssql

解析:

  1. 启动一个新的容器并且从 mssql 容器进行挂载数据卷 (设置了此容器自动移除 --rm
  2. 此容器挂载本地主机的文件夹 ($(pwd) 会输出当前终端的工作目录)作为容器的 /backup 目录
  3. 执行 tar cvf /backup/backup.tar /var/opt/mssql 来对 /var/opt/mssql 目录压缩为 backup.tar

因为此临时容器挂载了本地目录作为 /backup 目录, 所以当我们执行完上面的命令之后, 我们会发现本地目录,也就是当前工作目录下会有 backup.tar 文件产生。至此备份完毕。

还原

在创建一个 mssql 容器作为测试:

docker run -d -e "ACCEPT_EULA=Y" -e "MSSQL_SA_PASSWORD=<数据库SA账户的密码>" -p 1434:1433 --mount type=volume,src=mssql-vol2,dst=/var/opt/mssql --name mssql2 mcr.microsoft.com/mssq l/server

运行临时容器将备份文件解压缩至指定目录:

docker run --rm --volumes-from mssql2 --mount type=bind,src=$(pwd),dst=/backup ubuntu bash -c "tar xf /backup/backup.tar -C / && ls /var/opt/mssql/data -l"

执行完上述指令之后, 我们会看到数据库文件已经存在于 /var/opt/mssql/data 文件夹下,至此,还原操作已经完成。

下面是拓展内容:

我们上面使用的是 mssql 数据库, 这里文件的直接覆盖是不能完成附加操作的, 下面我们需要手动附加数据库:

docker exec -it mssql2 /bin/bash

/opt/mssql-tools/bin/sqlcmd -S . -U sa -P '<账户sa密码>'

使用 SELECT NAME FROM sys.Databases 来查看所有数据库名(需要键入 GO 才会执行)

sp_attach_db @dbname='需要附加的数据库名', @filename1='/var/opt/mssql/data/还原的数据库文件名'

执行完之后, 再使用 SELECT NAME FROM sys.Databases 就可以看到我们还原的数据库了

另外,官方网站上也给出了一种数据库备份还原的方式。

总结

应用数据的备份还原对于系统来说是至关重要的, Volume 与 Bind Mount 都是非常实用的持久化介质。

Docker 学习笔记(持久化数据的备份,还原)的更多相关文章

  1. Redis学习——Redis持久化之AOF备份方式保存数据

    新技术的出现一定是在老技术的基础之上,并且完善了老技术的某一些不足的地方,新技术和老技术就如同JAVA中的继承关系.子类(新技术)比父类(老技术)更加的强大! 在前面介绍了Redis学习--Redis ...

  2. Docker学习笔记总结

    Docker学习笔记 https://yeasy.gitbooks.io/docker_practice/content/   一 环境搭建 Ubuntu安装 .添加软件源的GPG密钥 curl -f ...

  3. Docker学习笔记之--.Net Core项目容器连接mssql容器(环境:centos7)

    前一节演示在docker中安装mssql,地址:Docker学习笔记之--安装mssql(Sql Server)并使用Navicat连接测试(环境:centos7) 本节演示 .Net Core项目容 ...

  4. Docker学习笔记 — 配置国内免费registry mirror

    Docker学习笔记 — 配置国内免费registry mirror Docker学习笔记 — 配置国内免费registry mirror

  5. docker学习笔记1 -- 安装和配置

    技术资料 docker中文官网:http://www.docker.org.cn/ 中文入门课程:http://www.docker.org.cn/book/docker.html docker学习笔 ...

  6. Docker学习笔记之一,搭建一个JAVA Tomcat运行环境

    Docker学习笔记之一,搭建一个JAVA Tomcat运行环境 前言 Docker旨在提供一种应用程序的自动化部署解决方案,在 Linux 系统上迅速创建一个容器(轻量级虚拟机)并部署和运行应用程序 ...

  7. Windows phone 8 学习笔记(2) 数据文件操作

    原文:Windows phone 8 学习笔记(2) 数据文件操作 Windows phone 8 应用用于数据文件存储访问的位置仅仅限于安装文件夹.本地文件夹(独立存储空间).媒体库和SD卡四个地方 ...

  8. docker~学习笔记索引

    回到占占推荐博客索引 使用docker也有段时间了,写了不少文章与总结,下面把它整理个目录出来,方便大家去学习与检索! docker~学习笔记索引 docker~linux下的部署和基本命令(2017 ...

  9. Docker学习笔记 - Docker容器内部署redis

    Docker学习笔记(2-4)Docker应用实验-redist server 和client的安装使用 一.获取redis容器(含客户端和服务端) 二.创建服务端容器 1.在终端A中运行redis- ...

随机推荐

  1. oracle学习笔记第一天

    oracle学习笔记第一天 --oracle学习的第一天 --一.几个基础的关键字   1.select select (挑选) 挑选出显示的--列--(可以多列,用“,”隔开,*表示所有列),为一条 ...

  2. SQL两表之间:根据一个表的字段更新另一个表的字段

    update table1 set field1=table2.field1,field2=table2.field2from table2where table1.id=table2.id

  3. Get all static wms goodlocation data

    sql function and store process: create function [dbo].[fun_splitin](@c varchar(),@split varchar()) r ...

  4. [ionic3.x开发记录]ios下页面过渡效果不出现的小坑

    如果内容没有被<ion-content></ion-content>或者<ion-header></ion-header>标签包裹,页面过渡的时候是没有 ...

  5. 玩转Vuejs--数组监听

    Vue中对数据的监听主要是依靠Object.defineProperty来实现的,这种实现主要是针对key/value形式的对象,对数组中值的变化是无能为力的,那么该如何对数组中的数据进行监听呢,下面 ...

  6. js中filter的用法

    filter也是一个常用的操作,它用于把Array的某些元素过滤掉,然后返回剩下的元素. 和map()类似,Array的filter()也接收一个函数.和map()不同的是,filter()把传入的函 ...

  7. Python类__call__()方法

    在python中,创建类型的时候定义了__call__()方法,那这个类型创建出来的实例就是可调用的.例def如: class A(object): def __init__(self,name,ag ...

  8. cocos2d-x C++ 获取网络图片缓存并展示

    #ifndef __HttpGetImg__ #define __HttpGetImg__ #include "cocos2d.h" #include "HttpRequ ...

  9. eclipse二、保证svn导入的项目正常运行

    1.环境说明 eclipse4.11 需要jdk1.8支持 公司项目大都jdk1.6与jdk1.5 为保持公司项目正常运行而配置jdk运行场景 2.window需按照jdk1.8.jdk1.6 jdk ...

  10. sort();对结构体数组的排序

    sort(); 位于C++ 头文件 #include<algorithm>中 数组排序(从小到大,从大到小) 结构体排序(数字参数从大到小...字符串为参数 字典序....) 代码示例:( ...