005.Docker存储管理
一 Docker volume形态
- 默认,即无Docker volume
- Data volume (数据卷)
- data container(数据卷容器)
二 默认无volume
三 Data volume (数据卷)
3.1 -v挂载容器内目录
- 数据卷是目录或文件,而非没有格式化的磁盘(块设备)
- 数据卷可以在容器之间共享和重用
- 对数据卷的修改会立马生效
- 对数据卷的更新,不会影响镜像
- 数据卷默认会一直存在,即使容器被删除
- -d:后台进程;
- -p:映射端口,物理机端口:容器端口;
- -v:物理机文件夹:容器的目录(容器中目录如果不存在,会自动创建,如果存在,会覆盖掉),即将宿主机中的目录挂载到镜像中的目录。
类型
|
挂载固定目录
|
自动映射目录
|
volume 位置
|
可任意指定
|
/var/lib/docker/volumes/……
|
对已有mount point 影响
|
隐藏并替换为 volume
|
原有数据复制到 volume
|
是否支持单个文件
|
支持
|
不支持,只能是目录
|
权限控制
|
可设置为只读,默认为读写权限
|
无控制,均为读写权限
|
移植性
|
移植性弱,与host path绑定
|
移植性强,无需指定host目录
|
root@docker:~# docker inspect b7 | grep -A11 "Mounts"
root@docker:~# echo "Hello web01!" >/webroot/index.html
root@docker:~# echo "Hello web02!" >/var/lib/docker/volumes/725d7d76ec8eb10f5730fe5663cb1d1eb7481efaa2a5a790343dca5d0557564a/_data/index.html
3.2 -v挂载文件
root@docker:~# docker run --rm -it --name centos7-01 -v ~/.bashrc:/root/.bashrc centos:7
四 docker的数据共享
4.1 docker容器与宿主机共享数据
docker cp [OPTIONS] CONTAINER:PATH LOCALPATH|-
docker cp [OPTIONS] LOCALPATH|- CONTAINER:PATH
root@docker:~# docker cp /root/.vimrc centos7-01:/root/ #从宿主机拷贝至容器
root@docker:~# docker cp centos7-01:/root/.vimrc /root/.vimrc_bak #从容器拷贝至宿主机
4.2 docker容器之间共享数据
root@docker:~# docker run -d -p 1010:80/tcp --name web03 -v /webroot:/usr/local/apache2/htdocs httpd
root@docker:~# docker run -d -p 2020:80/tcp --name web04 -v /webroot:/usr/local/apache2/htdocs httpd
root@docker:~# echo "This is share file!" >/webroot/index.html
4.2 docker容器与容器共享数据
五 data container(数据卷容器)
5.1 创建数据卷容器
root@docker:~# docker create --name sharefile01 -v /data:/usr/local/apache2/htdocs centos:7
root@docker:~# docker inspect sharefile01 | grep -A11 "Mounts"
5.2 引用数据卷容器
root@docker:~# docker run -d -p 3030:80/tcp --name web05 --volumes-from sharefile01 httpd
root@docker:~# docker run -d -p 4040:80/tcp --name web06 --volumes-from sharefile01 httpd
root@docker:~# echo "This is share file two!" >/data/index.html
六 volume管理
6.1 创建volume卷
root@docker:~# docker volume create --name data02
root@docker:~# docker volume inspect data02
6.2 使用volume卷
root@docker:~# docker run -d -p 5050:80/tcp --name web07 -v data02:/usr/local/apache2/htdocs httpd
root@docker:~# echo "Hello web07!" > /var/lib/docker/volumes/data02/_data/index.html
6.3 查看volume卷
root@docker:~# docker volume ls #查看所有volume卷
root@docker:~# docker volume ls -qf dangling=true #查看所有孤儿卷
6.4 删除volume卷
root@docker:~# docker volume rm 95704ae78c05261a46d2dc1f2bf872a8c3dc634817e7c0db53e7e6d40f2dc8ea
root@docker:~# docker volume rm $(docker volume ls -qf dangling=true) #删除孤儿卷
6.5 删除容器时删除 volume
root@docker:~# docker run -d -p 6060:80/tcp --name web08 -v /usr/local/apache2/htdocs httpd
root@docker:~# docker inspect web08
root@docker:~# docker rm -vf web08
root@docker:~# docker volume ls
七 volume数据备份及还原
7.1 备份
root@docker:~# docker run -d -p 1111:80/tcp --name web09 -v /usr/local/apache2/htdocs httpd
root@docker:~# docker inspect web09 | grep -A11 "Mounts"
root@docker:~# echo "This is web09 backup test!">/var/lib/docker/volumes/16aa6956e7076ecb9f256c302833640880e3bb1b8602771cca378e7230975488/_data/index.html
root@docker:~# docker run --volumes-from web09 --name mydatabackup -v /mybackup:/databack httpd tar zcf /databack/http-backup.tar.gz /usr/local/apache2/htdocs
7.2 还原
root@docker:~# docker run -d -v /usr/local/apache2/htdocs --name temp01 httpd
root@docker:~# docker run --volumes-from temp01 --name web10 -v /mybackup:/databack httpd tar zxf /databack/http-backup.tar.gz
#此步骤执行完毕即将备份文件已经还原至容器的/usr/local/apache2/htdocs。
root@docker:~# docker run -d -p 2222:80/tcp --name web11 --volumes-from temp01 httpd
005.Docker存储管理的更多相关文章
- docker存储管理及实例
一.Docker存储概念 1.容器本地存储与Docke存储驱动 容器本地存储:每个容器都被自动分配了内部存储,即容器本地存储.采用的是联合文件系统.通过存储驱动进行管理. 存储驱动:控制镜像和容器在 ...
- Docker入门 - 005 Docker 容器连接
Docker 容器连接 前面我们实现了通过网络端口来访问运行在docker容器内的服务.下面我们来实现通过端口连接到一个docker容器 网络端口映射 我们创建了一个 python 应用的容器. do ...
- 附005.Docker Compose文件详解
一 Docker Compose文件简介 compose文件使用yml格式,主要分为了四个区域: version:用于指定当前docker-compose.yml语法遵循哪个版本 services:服 ...
- docker存储管理
Docker 镜像的元数据 repository元数据 repository在本地的持久化文件存放于/var/lib/docker/image/overlay2/repositories.json中 ...
- 附007.Docker全系列大总结
Docker全系列总结如下,后期不定期更新. 欢迎基于学习.交流目的的转载和分享,禁止任何商业盗用,同时希望能带上原文出处,尊重ITer的成果,也是尊重知识. 若发现任何错误或纰漏,留言反馈或右侧添加 ...
- 云计算Docker全面项目实战(Maven+Jenkins、日志管理ELK、WordPress博客镜像)
2013年,云计算领域从此多了一个名词“Docker”.以轻量著称,更好的去解决应用打包和部署.之前我们一直在构建Iaas,但通过Iaas去实现统一功 能还是相当复杂得,并且维护复杂.将特殊性封装到 ...
- 附003.Docker Compose命令详解
一 Docker Compose命令格式 Usage: docker-compose [-f <arg>...] [options] [COMMAND] [ARGS...] docker- ...
- Docker之存储管理
本文由作者邹珍珍授权网易云社区发布. 本文主要介绍Docker的存储管理.Docker拥有镜像分层,写时复制机制以及内容寻址存储等特征,为了支持这些特征,Docker设计了一套镜像元数据管理机制来管理 ...
- Docker 镜像之存储管理
笔者在<Docker 镜像之进阶篇>中介绍了镜像分层.写时复制以及内容寻址存储(content-addressable storage)等技术特性,为了支持这些特性,docker 设计了一 ...
随机推荐
- HTML5中<template>标签的详细介绍
HTML5中<template>标签的详细介绍(图文) 这篇文章主要介绍了HTML5中的template标签,是HTML5入门中的重要知识,需要的朋友可以参考 一.HTML5 templa ...
- python3之requests
1.requests简介 requests是通过urllib3实现自动发送HTTP/1.1请求,它能轻松的实现cookies,登陆验证,代理设置等操作. Python内置的urllib模块,用于访问网 ...
- linux 定期清除日志
clearLog.sh #!/bin/sh find /usr/local/apache/logs -mtime + 30 -name "*.log" -exec rm {} \; ...
- centos 编译安装PHP5.4
2013年12月29日 19:52:30 已经安装好Apache 2.4 php版本 5.4 ./configure --prefix=/usr/local/lamp/php --with-apxs2 ...
- Python中的一些小语法
目录: 生成随机数 将一个字符串变为datetime类型,并且获取星期几 1.生成随机数 假设我们要操作的list如下: >>> import random >>> ...
- Android:Service
Android Service: http://www.apkbus.com/android-15649-1-1.html android service 的各种用法(IPC.AIDL): http: ...
- python装饰器@用法
这个是我见过比较好的讲解链接: [廖雪峰的官方网站 - 装饰器]
- js发送get 、post请求的方法简介
POST请求: 发送的参数格式不同,请求头设置不同,具体参照 Http请求中请求头Content-Type讲解 发送的参数格式不同,后台获取方式也不相同 php请看 php获取POST数据的三种方法 ...
- Python 正则表达式模块 (re) 简介
Python 的 re 模块(Regular Expression 正则表达式)提供各种正则表达式的匹配操作,和 Perl 脚本的正则表达式功能类似,使用这一内嵌于 Python 的语言工具,尽管不能 ...
- js数值进制互转
十进制转换为二进制: var num = 100; console.log(num.toString(2)); toString()方法可把一个 Number 对象转换为一个字符串,并返回结果. 语法 ...