实例解析Docker数据卷+数据卷容器+flocker数据共享+DockerHub操作

简介: Docker内部数据管理和Docker之间的数据共享为数据卷和数据卷容器,实例解析1.将本地的文件作为容器的数据卷,2.数据卷flocker插件实现容器集群(或者Docker Swarm)的数据共享3.数据卷容器作为其他容器的数据卷.降低磁盘开销.4.数据的备份,恢复和迁移.5.Docker hub的常用操作.1.0.数据卷(Data volumes)Data vol

Docker内部数据管理和Docker之间的数据共享为数据卷和数据卷容器,实例解析1.将本地的文件作为容器的数据卷,2.数据卷flocker插件实现容器集群(或者Docker Swarm)的数据共享3.数据卷容器作为其他容器的数据卷.降低磁盘开销.4.数据的备份,恢复和迁移.5.Docker hub的常用操作.

1.0.数据卷(Data volumes)

Data volumes是一个或者多个容器特别指定的目录,它区别于联合文件系统的(Union File System,或称UnionFS,通过底层的操作的文件系统,具有轻量级和快速的特性,Docker 容器也是使用联合文件系统去创建数据块的.),并且,对容器的数据管理以及容器之间数据共享提供了以下几点:
- 当容器被创建的同时,数据卷已经被初始化了.当镜像数据在制定的挂载点上时,存在的数据会复制到新的卷上.(但是,如果挂载的是主机路径不适用)
- 容器之间的数据卷可以重用和共享.
- 可以直接更改数据卷
- 镜像更新不会更改数据卷.
- 容器被删除,数据卷不受影响.

1.1.增加一个数据卷

docker createdocker run命令中,使用-v 为容器增加一个数据卷.

wxl@wxl-pc:~$ docker run -d -P --name myweb -v /webapp training/webapp python app.py

这里写图片描述

可见.把training/webapp命名为myweb,并且通过-v创建了数据卷 /webapp

  • Tip,在Dockerfile创建新的容器时,可以通过-v来创建更多的数据卷.

1.2.查看创建信息

wxl@wxl-pc:~$ docker inspect myweb

这里写图片描述

其中,Mount信息,包含了刚刚创建的数据卷详细信息.source指定了本机路径,而Destination则指定容器内部路径.

1.3.本机路径作为容器数据卷

将本机的路径如/src/webapp作为volumeweb的数据卷.这样做的好处是,如果本地有代码可很方便在本地修改,在容器里查看修改后的效果.

wxl@wxl-pc:~$ docker run -d -P --name volumeweb -v /src/webapp:/opt/webapp training/webapp python app.py

3206809decc4145427cb1f300d05a55aae88a6fffc33596e773dbd023746e479

#查看
wxl@wxl-pc:~$ docker inspect volumeweb

这里写图片描述

1.4.设置本地路径的权限,默认是rw读写模式,可以制定能如ro只读模式

wxl@wxl-pc:~$ docker run -d -P --name volumeweb -v /src/webapp:/opt/webapp:ro training/webapp python app.py

仅仅在/src/webapp:/opt/webapp:ro 增加了ro,指明只读模式.

1.5.挂载主机文件作为数据卷

使用-v标志可以挂载单一文件,如将主机的bash_history文件内容,添加至新创建的容器中,此时新创建的容器的bash_history中的记录删除而存上主机bash_history的内容.

wxl@wxl-pc:~$ docker run --rm -it -v ~/.bash_history:/root/.bash_history ubuntu:14.04 /bin/bash

这里写图片描述

2.flocker插件实现容器集群的数据管理,共享和迁移等.(如果未配置Docker Swarm,建议跳过本步骤)

挂载一个共享数据作为Docker容器的数据卷
容器除了可以在本机上的路径作为数据卷外,还可以通过Docker volume plugins来允许一些共享数据作为数据卷,如iSCSI,NFS或者FC.这样做的好处是,共享的数据卷的位置不受容器的影响,而且只要某个容器拥有volume plugins并且能够访问,就可以将共享数据卷作为该容器的数据卷.

2.1.安装Docker容器卷驱动flocker

数据卷的一个插件,用来管理共享数据,支持容器之间(容器集群)的共享数据进行迁移,打包.
注意:a.最后一步下载flocker插件时,可能因为网速而下载时间很长,建议下载的flocker时跳过.Docker 数据卷flocker插件实现容器集群的数据管理,共享和迁移等.步骤,不影响后续操作.b.本过程需要flocker正确安装,Dcoker集群环境,如果提示没有flocker插件错误,可以跳过本步骤,Docker Swarm不是本次解析重点.

wxl@wxl-pc:~$ sudo apt-get update

wxl@wxl-pc:~$ sudo apt-get -y install apt-transport-https software-properties-common

wxl@wxl-pc:~$ sudo add-apt-repository -y "deb https://clusterhq-archive.s3.amazonaws.com/ubuntu/$(lsb_release --release --short)/\$(ARCH) /"

wxl@wxl-pc:~$ cat <<EOF > /tmp/apt-pref
> Package: *
> Pin: origin clusterhq-archive.s3.amazonaws.com
> Pin-Priority: 700
> EOF

wxl@wxl-pc:~$ sudo mv /tmp/apt-pref /etc/apt/preferences.d/buildbot-700

wxl@wxl-pc:~$ sudo apt-get update
#下载速度很慢,根据网速而定.
wxl@wxl-pc:~$ sudo apt-get -y install --force-yes clusterhq-flocker-cli

这里写图片描述

安装Flocker Node Services(略过,过程繁琐,不再赘述,可以去clusterhq官方文档查看.)

wxl@wxl-pc:~$ docker volume create -d flocker --name my-named-volume -o size=20GB


wxl@wxl-pc:~$ docker run -d -P \
> -v my-named-volume:/opt/webapp \
> --name web training/webapp python app.py

本过程需要flocker正确安装,Dcoker集群环境,如果提示没有flocker插件错误,可以跳过本步骤,Docker Swarm不是本次解析重点.

3.创建一个新的数据卷容器,作为其他应用层容器的数据卷

创建新的数据卷的容器目的是,方便一些持久性(存储)的数据在容器和容器之间共享.
使用postgres镜像创建一个数据卷容器,该容器没有应用运行,所以,其他容器的可以作为应用层,而存储的数据放在数据卷容器中,这样可以节省磁盘空间.

3.1.创建新的数据卷容器dbstore

wxl@wxl-pc:~$ docker create -v /dbdata --name dbstore training/postgres /bin/true

3.2.使用--volumes-from可以将dbdata容器中的数据卷/dbdata挂载到另一个容器中(db1).

wxl@wxl-pc:~$ docker run -d --volumes-from dbstore --name db1 training/postgres

3.3.将dbstore挂载到db2容器中.

docker run -d --volumes-from dbstore --name db2 training/postgres

3.4.通过已经挂载的容器扩展挂载(如,db3通过db1或者db2来挂载dbstore数据卷容器)

这里写图片描述

如果,删除容器db1或者容器db2,数据卷是不会被删除的,如果在磁盘上删除数据卷,必须显示调用docker rm -v加上数据卷.

3.5.注意,如果删除含有数据卷的容器,在删除容器时没有使用-v标志,这些数据卷会成为dangling状态

a.显示所以没有挂载到容器上的数据卷

docker volume ls -f dangling=true

b.删除这些dangling状态的数据卷

docker volume rm <volume name>

4.0.备份,恢复,迁移数据卷

Docker容器的数据卷备份,恢复,迁移一般是通过--volumes-from标志实现的.

4.1.备份,创建一个新容器,在新容器挂载dbstore数据卷容器,并将dbstore数据卷打包为backup.tar文件,备份至新创建的容器中.

wxl@wxl-pc:~$ docker run --rm --volumes-from dbstore -v $(pwd):/backup ubuntu:14.04 tar cvf /backup/backup.tar /dbdata

这里写图片描述

4.2.恢复,通过-v标志,将数据恢复到同一个容器或者其他任意容器.

wxl@wxl-pc:~$ docker run -v /dbdata --name dbstore2 ubuntu:14.04 /bin/bash

4.3.迁移,其实就是通过解压方式,将dbstore数据卷容器的数据解压至一个新的容器.

wxl@wxl-pc:~$ docker run --rm --volumes-from dbstore2 -v $(pwd):/backup ubuntu:14.04 bash -c "cd /dbdata && tar xvf /backup/backup.tar --strip 1"

这里写图片描述

5.Docker Hub常见操作

Docker Hub是Docker官方提供的容器管理工程,类似与github,不同在于在Docker Hub中搜索存放的不是源码而是容器.
Docker Hub可以存放我们创建的容器,如果是公开的则大家都以拿来用,也支持不公开.

5.1.首先注册Docker Hub账号,然后登陆

wxl@wxl-pc:~$ docker login

这里写图片描述

登陆信息存放在了$HOME/.docker/config.json下.

5.2.查找并下载需要的容器

#查找
wxl@wxl-pc:~$ docker search centos
#下载
wxl@wxl-pc:~$ docker pull centos

这里写图片描述

5.3.推送到Docker Hub上

使用docker push yourname/newimage来push自己的容器到hub上.

wxl@wxl-pc:~$ docker push mycentos:mydev

这里写图片描述

目录
相关文章
|
NoSQL Java Linux
《docker高级篇(大厂进阶):2.DockerFile解析》包括:是什么、DockerFile构建过程解析、DockerFile常用保留字指令、案例、小总结
《docker高级篇(大厂进阶):2.DockerFile解析》包括:是什么、DockerFile构建过程解析、DockerFile常用保留字指令、案例、小总结
622 76
|
数据采集 JSON 数据可视化
JSON数据解析实战:从嵌套结构到结构化表格
在信息爆炸的时代,从杂乱数据中提取精准知识图谱是数据侦探的挑战。本文以Google Scholar为例,解析嵌套JSON数据,提取文献信息并转换为结构化表格,通过Graphviz制作技术关系图谱,揭示文献间的隐秘联系。代码涵盖代理IP、请求头设置、JSON解析及可视化,提供完整实战案例。
807 4
JSON数据解析实战:从嵌套结构到结构化表格
|
存储 搜索推荐 大数据
数据大爆炸:解析大数据的起源及其对未来的启示
数据大爆炸:解析大数据的起源及其对未来的启示
873 15
数据大爆炸:解析大数据的起源及其对未来的启示
|
JSON 监控 网络协议
Bilibili直播信息流:连接方法与数据解析
本文详细介绍了自行实现B站直播WebSocket连接的完整流程。解析了基于WebSocket的应用层协议结构,涵盖认证包构建、心跳机制维护及数据包解析步骤,为开发者定制直播数据监控提供了完整技术方案。
1995 9
|
JSON 前端开发 搜索推荐
关于商品详情 API 接口 JSON 格式返回数据解析的示例
本文介绍商品详情API接口返回的JSON数据解析。最外层为`product`对象,包含商品基本信息(如id、name、price)、分类信息(category)、图片(images)、属性(attributes)、用户评价(reviews)、库存(stock)和卖家信息(seller)。每个字段详细描述了商品的不同方面,帮助开发者准确提取和展示数据。具体结构和字段含义需结合实际业务需求和API文档理解。
|
机器学习/深度学习 JSON 算法
淘宝拍立淘按图搜索API接口系列的应用与数据解析
淘宝拍立淘按图搜索API接口是阿里巴巴旗下淘宝平台提供的一项基于图像识别技术的创新服务。以下是对该接口系列的应用与数据解析的详细分析
|
Java API 数据处理
深潜数据海洋:Java文件读写全面解析与实战指南
通过本文的详细解析与实战示例,您可以系统地掌握Java中各种文件读写操作,从基本的读写到高效的NIO操作,再到文件复制、移动和删除。希望这些内容能够帮助您在实际项目中处理文件数据,提高开发效率和代码质量。
754 4
|
数据采集 监控 搜索推荐
深度解析淘宝商品详情API接口:解锁电商数据新维度,驱动业务增长
淘宝商品详情API接口,是淘宝开放平台为第三方开发者提供的一套用于获取淘宝、天猫等电商平台商品详细信息的应用程序接口。该接口涵盖了商品的基本信息(如标题、价格、图片)、属性参数、库存状况、销量评价、物流信息等,是电商企业实现商品管理、市场分析、营销策略制定等功能的得力助手。
|
数据采集 前端开发 API
SurfGen爬虫:解析HTML与提取关键数据
SurfGen爬虫:解析HTML与提取关键数据
|
JSON 缓存 API
解析电商商品详情API接口系列,json数据示例参考
电商商品详情API接口是电商平台的重要组成部分,提供了商品的详细信息,支持用户进行商品浏览和购买决策。通过合理的API设计和优化,可以提升系统性能和用户体验。希望本文的解析和示例能够为开发者提供参考,帮助构建高效、可靠的电商系统。
653 12