Docker系统七:Docker数据管理
Docker的数据管理
I. 基本概念
Docker容器一旦删除,其相关的rootf文件系统就会被删除,其容器内的数据将一并删除,为了保存相关数据,Docker提出了数据卷的概念。
II. 数据卷
Docker中与数据卷相关的参数:
-v=[]; 创建数据卷
--volumes-from; 数据卷容器
1)创建数据卷
-v 参数:
* host-dir: 表示host上的目录,如果不存在,Docker会自动在Host上创建该目录;
* container-dir:表示容器内部对应的目录,如果不存在,Docker会在容器内部创建此目录;
* rw|ro :用于对控制卷的读写权限;
不指定host-dir去创建一个数据卷:
$docker run -it --rm -v /volume1 --name test1 ubuntu:14.04 /bin/bash
$df -lf
Filesystem Size Used Avail Use% Mounted on
none 40G 4.9G 33G 14% /
tmpfs 497M 0 497M 0% /dev
tmpfs 497M 0 497M 0% /sys/fs/cgroup
/dev/vda1 40G 4.9G 33G 14% /volume1
shm 64M 0 64M 0% /dev/shm
tmpfs 497M 0 497M 0% /sys/firmware
$ls /volume1/
$echo "volume1" > /volume1/test.ext
$ls /volume1/
test.txt
通过查看发现Host的根分区被挂载到了容器的/volume1. 实际上Docker会在Host的/var/lib/docker/vfs/dir/(centos, 其他系统可能不同)目录中随机生成一个目录,然后挂载容器的/volume1;
可以查看容器详细配置Mounts捉的Source:
$docker inspect test1
"Mounts": [
{
"Type": "volume",
"Name": "5bf4ad339dad3c7fbecb0537c1a0a0065e70109beb4194475d1de153542b582b",
"Source": "/var/lib/docker/volumes/5bf4ad339dad3c7fbecb0537c1a0a0065e70109beb4194475d1de153542b582b/_data",
"Destination": "/volume1",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
],
这种方式创建的数据卷当没有基他容器依赖时,会随容器的删除而删除,同时对应的Host目录也会被删除,如查不想Host的目录被删除,需要启动时指定Host目录。
2)挂载Host的目录做为数据卷
$docker run -it --rm -v /data/volume1:/volume1 ubuntu:14.04 /bin/bash
$df -lh
tmpfs 497M 0 497M 0% /dev
tmpfs 497M 0 497M 0% /sys/fs/cgroup
/dev/vda1 40G 5.3G 32G 15% /volume1
shm 64M 0 64M 0% /dev/shm
tmpfs 497M 0 497M 0% /sys/firmware
$ls /volume/
$echo "hello"> /volume1/hello.txt
$exit
$ls /data/volume1/
hello.txt
$cat /data/volume1/hello.txt
hello
这样即使容器被删除,host内的目录仍然含有容器的相关数据文件,这种也是容器与Host进行数据交换的一种方式。实际上Docker内部是通过mount --bind来实现的。
容器对挂载的数据据具有读写权限控制:如挂载目录为只读权限
$docker run -it --rm -v /data/volume1:/volume1:ro ubuntu:14.04 /bin/bash
$df -lh
$touch /volume1/hello.txt
touch: cannot touch 'test.text': Read-only file system
3) 挂载Host的文件作为数据卷(此方法一般用于Host与容器间共享配置文件)
- 通过挂载Host 的bash历史命令文件,在容器中查看Host的bash历史命令,当容器删除时,Host也能查看容器的执行命令历史
docker run --rm -it -v ~/.bash_history:/root/.bash_history ubuntu:14.04 /bin/bash
- 同步Host与容器里的时区,挂载/etc/localtime到容器内部
docker run -it --rm -v /etc/localtime:/ect/localtime ubuntu:14.04 /bin/bash
III. 数据卷容器
--volumes-from 参数用于数据卷有关的场景
1) 创建和挂载数据卷
- 创建一个dabdata的容器,其包含一个/dbdata的数据卷
$docker run -d -v /dbdata --name dbdata training/postgres echo Data-only container for postgres
- 通过--volumes-from在其他容器中挂载/dbdata的数据卷
docker run -d --volumes-from dbdata --name db1 training/postgres
docker run -d --volumes-from dbtata --name db2 training/postgres
docker run -d --name db3 --volumes-from db1 training/postgres
如此这样,db1和db2都能看到容器dbdata所有的数据卷(/dbdata)的内容,db3 是从其他已经挂载容器卷的容器挂载数据卷。
当我们删除挂载数据卷的容器时,数据卷不会被删除,只能所有引用的容器被删除后,通过docker rm -v 显式删除数据卷。
2)数据卷容器的使用
使用数据卷进行多容器日志收集
构建rsyslog镜像(使用Dockerfile)
- Dockerfile 内容
#forrsyslog
FROM centos6
MAINTAINER hustcat
RUN yum -y install rsyslog && yum clean all
CMD rsyslogd -n
VOLUME /dev
VOLUME /var/log
- run Dockerfile
docker build -t hustcat/rsyslog
运行rsyslog容器
docker run --name rsyslog -d -v /tmp/syslogdev:/devhustcat/rsyslog
ls /tmp/syslogdev/log -lh
从其他容器写log到日志容器
docker run --rm -v /tmp/syslogdev/log:/dev/log centos6 logger -p info "hello rsyslog"
IV. 备份、恢复和迁移数据卷
1). 备份
docker run --volumes-from dbdata -v ${pwd}:/backup ubuntu tar cvf /backup/backup.tar /dbdata
- 创建一下新容器, 将Host本地目录挂载到/backup;
- 将数据卷容器dbdata的数据卷/dbdata打包到/backup/backup.tar
- 在Host的当前目录即可看到backup.tar
2). 恢复
将backup.tar的数据恢复到一个新的容器dbdata2中
docker run -v /dbdata --name dbdata2 ubuntu /bin/bash
docker run --volumes-from dbdata2 -v ${pwd}:/backup busybox tar xvf /backup/backup.tar
Docker系统七:Docker数据管理的更多相关文章
- BI系统打包Docker镜像及容器化部署的具体实现
在过去的几年中,"云"作为明星热词站在了各种新潮技术之中,你可能使用过,但说不清它的原理:或者是没用过,但听过它的大名:也可能连它的名字都没听过,但你对这只蓝色鲸鱼一定十分眼熟.作 ...
- 【新技术】CentOS系统下docker的安装配置及使用详解
1 docker简介 Docker 提供了一个可以运行你的应用程序的封套(envelope),或者说容器.它原本是dotCloud 启动的一个业余项目,并在前些时候开源了.它吸引了大量的关注和讨 ...
- centos7系统下 docker 环境搭建
运行环境: VMware Workstation Pro 在虚拟机中安装centos7系统, 选择最小安装, 网络连接方式选择的桥接(与宿主机在同一IP段)centos7一定要安装64位, docke ...
- Centos系统下Docker的安装
一.检查内核版本 安装Docker,需要linux内核大于3.10 使用uname -r 来检查 二. Centos系统下Docker的安装 1. 安装需要的软件包 yum install -y yu ...
- CentOS系统下docker的安装与卸载
Docker简介 Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制, ...
- 系统学习Docker 践行DevOps理念
Docker代表的容器技术是近两年的大热技术,和人工智能.区块链等热点不同,容器技术的门槛并不高,每一个开发.测试.运维人员都能在日常工作中掌握和使用,是当今IT从业人员的必备技能之一.本课程会带大家 ...
- 在Mac OSX系统的Docker机上启用Docker远程API功能
在Mac OSX系统的Docker机上启用Docker远程API功能 作者:chszs,未经博主同意不得转载.经许可的转载需注明作者和博客主页:http://blog.csdn.net/chszs D ...
- Docker -- 系统整洁之道 -- 1
在上文Docker – 系统整洁之道 – 0中已经对Docker是什么,安装Docker以及怎么运行一个简单的容器有了初步了解,这篇文章介绍Docker的一些命令和Docker镜像的使用及操作. 一些 ...
- (七) Docker 部署 MySql8.0 一主一从 高可用集群
参考并感谢 官方文档 https://hub.docker.com/_/mysql y0ngb1n https://www.jianshu.com/p/0439206e1f28 vito0319 ht ...
随机推荐
- Netty 编解码技术 数据通信和心跳监控案例
Netty 编解码技术 数据通信和心跳监控案例 多台服务器之间在进行跨进程服务调用时,需要使用特定的编解码技术,对需要进行网络传输的对象做编码和解码操作,以便完成远程调用.Netty提供了完善,易扩展 ...
- awk运用
awk编程: 1. 变量: 在awk中变量无须定义即可使用,变量在赋值时即已经完成了定义.变量的类型可以是数字.字符串.根据使用的不同,未初始化变量的值为0或空白字符串" ",这主 ...
- python selenium 鼠标悬停
#鼠标悬停 chain = ActionChains(driver) implement = driver.find_element_by_link_text() chain.move_to_elem ...
- 只用120行Java代码写一个自己的区块链
区块链是目前最热门的话题,广大读者都听说过比特币,或许还有智能合约,相信大家都非常想了解这一切是如何工作的.这篇文章就是帮助你使用 Java 语言来实现一个简单的区块链,用不到 120 行代码来揭示区 ...
- 窗口缩小div内容隐藏看不到怎么解决?
div的宽度设置为100%,并设置其背景颜色,但当窗口发生变化出现横向滚动条,拉滚动条的时候发现右面是空白的. 解决方法:body{min-width:1024px},给body加上一个最小宽度.ie ...
- 前端-高潮 jQuery
jQuery:就是让页面动起来 参考手册:http://jquery.cuishifeng.cn/ DOM/BOM/javaScript 继承的类库 <--->模块 一.查找元素 二.操作 ...
- web.xml 文件中一般包括 servlet, spring, filter, listenr的配置的加载顺序
首先可以肯定 加载顺序与他们在web.xml 文件中的先后顺序无关. web.xml 中 listener 和 serverlet 的加载顺序为 先 listener 后serverlet最终得出结果 ...
- 夏令营讲课内容整理 Day 4.
本日主要内容就是搜索(打暴力 搜索可以说是OIer必会的算法,同时也是OI系列赛事常考的算法之一. 有很多的题目都可以通过暴力搜索拿到部分分,而在暴力搜索的基础上再加一些剪枝优化, 就有可能会拿到更多 ...
- BZOJ 2683: 简单题 [CDQ分治]
同上题 那你为什么又发一个? 因为我用另一种写法又写了一遍... 不用排序,$CDQ$分治的时候归并排序 快了1000ms... #include <iostream> #include ...
- RDB持久化
redis是一个内存数据库,所有我们需要将他定时存在磁盘上,如果没有开启AOF,那么会生成RDB文件进行存储,其实就是个二进制文件 RBD文件通过SAVE BGSAVE进行创建, SAVE会阻塞服务器 ...