DOCKER学习_014:Docker存储补充
在前面已经学习了Docker的存储,https://www.cnblogs.com/zyxnhr/p/11830238.html,现在对前面的内容的一个补充,具体请参考https://www.cnblogs.com/zyxnhr/p/11830238.html
对docker的数据进行持久化
接上一章实验
[root@docker-server3 nginx]# docker run -d -v /data:/usr/share/nginx/html nginx:v1.4
693f7819a0301e6432d69cc1f278596d96aa8a980050b7d26815b44d9390bc66
[root@docker-server3 nginx]# docker ps -a
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
693f7819a030 nginx:v1.4 "/build.sh nginx -g …" 4 seconds ago Up 3 seconds 80/tcp affectionate_chebyshev
3b26204c8758 nginx:v1.4 "/build.sh nginx -g …" 48 minutes ago Up 48 minutes 80/tcp thirsty_golick
0fef39ec7ffd nginx:v1.4 "/build.sh nginx -g …" 50 minutes ago Up 50 minutes 80/tcp flamboyant_dirac
9de02f005f66 nginx:v1.3 "/build.sh nginx -g …" 54 minutes ago Exited (0) 54 minutes ago flamboyant_poincare
593a35ccbbf9 nginx:v1.2 "nginx -g 'daemon of…" About an hour ago Up About an hour 80/tcp cool_clarke
55645329c490 nginx:v1.2 "nginx -g 'daemon of…" About an hour ago Up About an hour 80/tcp intelligent_carson
666927b25d2f nginx:v1.1 "nginx -g 'daemon of…" 2 hours ago Up 2 hours 80/tcp xenodochial_austin
[root@docker-server3 nginx]# docker inspect 693f7819a030 |grep IP
"LinkLocalIPv6Address": "",
"LinkLocalIPv6PrefixLen": 0,
"SecondaryIPAddresses": null,
"SecondaryIPv6Addresses": null,
"GlobalIPv6Address": "",
"GlobalIPv6PrefixLen": 0,
"IPAddress": "192.168.0.6",
"IPPrefixLen": 24,
"IPv6Gateway": "",
"IPAMConfig": null,
"IPAddress": "192.168.0.6",
"IPPrefixLen": 24,
"IPv6Gateway": "",
"GlobalIPv6Address": "",
"GlobalIPv6PrefixLen": 0,
[root@docker-server3 nginx]# curl http://192.168.0.6
自动创建/data目录
查看/data下数据
[root@docker-server3 nginx]# ll /data/
total 4
-rw-r--r-- 1 root root 12 Jan 2 17:54 index.html
[root@docker-server3 nginx]# cat /data/index.html
just a test
修改这个数据,会立即生效
[root@docker-server3 nginx]# echo aaaaa > /data/index.html
[root@docker-server3 nginx]# curl http://192.168.0.6
aaaaa
进入docker容器内部查看
[root@docker-server3 nginx]# docker exec -it 693f7819a030 /bin/bash
[root@693f7819a030 html]# ll
total 4
-rw-r--r-- 1 root root 6 Jan 2 22:57 index.html
[root@693f7819a030 html]# pwd
/usr/share/nginx/html
[root@693f7819a030 html]# cat index.html
aaaaa
[root@693f7819a030 html]# exit
exit
实现持久存储
使用Dockerfile的VOLUME指令
[root@docker-server3 nginx]# vi Dockerfile
FROM centos:7
WORKDIR /usr/share/nginx/html
ADD build.sh /build.sh
RUN yum install -y wget && wget -O /etc/yum.repos.d/epel.repo http://mirrors.aliyun.com/repo/epel-7.repo \
&& yum -y install nginx && rm -rf index.html && echo "nginx in custom docker" > index.html && chmod +x /build.sh EXPOSE 80 ENTRYPOINT ["/build.sh"]
VOLUME /usr/share/nginx/html
CMD ["nginx","-g","daemon off;"]
[root@docker-server3 nginx]# docker build -t nginx:v1.5 .
[root@docker-server3 nginx]# docker run -d nginx:v1.5
a6c195265c4ba5cd786040988e3e5a11eb0c63b1d726657620a76438fcafdbfe
这里没有指定本机的挂载目录,查看挂载位置
[root@docker-server3 nginx]# docker inspect a6c195265c |grep -A 10 Mount
"MountLabel": "",
"ProcessLabel": "",
"AppArmorProfile": "",
"ExecIDs": null,
"HostConfig": {
"Binds": null,
"ContainerIDFile": "",
"LogConfig": {
"Type": "journald",
"Config": {}
},
--
"Mounts": [
{
"Type": "volume",
"Name": "fb7d3ec98bf52d43d832088b752417826a893d30719ea11186b3a72981db6b9c",
"Source": "/var/lib/docker/volumes/fb7d3ec98bf52d43d832088b752417826a893d30719ea11186b3a72981db6b9c/_data", #挂载的本机位置
"Destination": "/usr/share/nginx/html",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
默认挂载的本机位置是"Source": "/var/lib/docker/volumes/fb7d3ec98bf52d43d832088b752417826a893d30719ea11186b3a72981db6b9c/_data"
容器ID下的一个_data目录
[root@docker-server3 nginx]# cd /var/lib/docker/volumes/fb7d3ec98bf52d43d832088b752417826a893d30719ea11186b3a72981db6b9c/_data
[root@docker-server3 _data]# ll
这种挂载会将容器的数据映射出来
[root@docker-server3 _data]# docker run -d -v /tmp/test:/usr/share/nginx/html nginx:v1.5
2c081745d680548dabda33d1f50043e362dcafbc1ea7e7d878ecb2a70a8d525d
[root@docker-server3 _data]# ll /tmp/test/
total 4
-rw-r--r-- 1 root root 12 Jan 2 18:12 index.html
这种方式就会覆盖掉内容
查看容器内时间
[root@docker-server3 _data]# docker exec -it 2c081745d6 /bin/bash
[root@2c081745d680 html]# date
Thu Jan 2 23:14:54 UTC 2020
[root@2c081745d680 html]# exit
exit
挂载文件
[root@docker-server3 _data]# docker run -d -v /etc/localtime:/etc/localtime nginx:v1.5
a4883fe9ce664110f7cd270a01d481aa18093f9375703c745fe93a89e6688f63
[root@docker-server3 _data]# docker exec -it a4883fe9c /bin/bash
[root@a4883fe9ce66 html]# date
Thu Jan 2 18:18:08 EST 2020
挂载多个目录
[root@docker-server3 _data]# docker run -d -v /etc/localtime:/etc/localtime -v /aaaa:/aaaa -v /tmp/test2:/usr/share/nginx/html nginx:v1.5
cfafe4c3c1b5d940679aa7eff49096bb4cbc2f112a2007ecf17320ad5e4209ea
[root@docker-server3 _data]# docker exec -it cfafe /bin/bash #进入查看
[root@cfafe4c3c1b5 html]# date
Thu Jan 2 18:21:13 EST 2020
[root@cfafe4c3c1b5 html]# ll /usr/share/nginx/html/
total 4
-rw-r--r-- 1 root root 12 Jan 2 18:21 index.html
[root@cfafe4c3c1b5 html]# df -hT
Filesystem Type Size Used Avail Use% Mounted on
overlay overlay 47G 4.1G 43G 9% /
tmpfs tmpfs 64M 0 64M 0% /dev
tmpfs tmpfs 910M 0 910M 0% /sys/fs/cgroup
shm tmpfs 64M 0 64M 0% /dev/shm
/dev/mapper/centos-root xfs 47G 4.1G 43G 9% /aaaa #挂载的
tmpfs tmpfs 910M 0 910M 0% /proc/asound
tmpfs tmpfs 910M 0 910M 0% /proc/acpi
tmpfs tmpfs 910M 0 910M 0% /proc/scsi
tmpfs tmpfs 910M 0 910M 0% /sys/firmware
设置挂载目录权限
[root@docker-server3 _data]# docker run -d -v /etc/localtime:/etc/localtime:ro -v /aaaa:/aaaa:rw -v /tmp/test2:/usr/share/nginx/html:ro nginx:v1.5
5ee7277878743c4f9053eb2f7af1dbf19f7bea30dca9992cd7f1b2ffea7bd71c
[root@docker-server3 _data]# docker exec -it 5ee727787 /bin/bash
[root@5ee727787874 html]# touch test.html
touch: cannot touch 'test.html': Read-only file system
[root@5ee727787874 html]# echo 111 > /etc/localtime
bash: /etc/localtime: Read-only file system
[root@5ee727787874 html]# touch /aaaa/test.html
[root@5ee727787874 html]# echo 1111 > /aaaa/test.html
[root@5ee727787874 html]# cat /aaaa/test.html
1111
但是可以通过宿主机修改
[root@docker-server3 _data]# echo 2222 /tmp/test2/index.html
2222 /tmp/test2/index.html
[root@docker-server3 _data]# echo 2222 > /tmp/test2/index.html
[root@docker-server3 _data]# cat /tmp/test2/index.html
2222
[root@docker-server3 _data]# docker exec -it 5ee727787 /bin/bash
[root@5ee727787874 html]# cat index.html
2222
删除容器顺便删除挂载的卷,可以指定-v参数
例如:
docker rm -fv 5ee727787874
这种方式可以删除Dockerfile内默认挂载的容器的卷目录,但是对于在外面指定挂载的目录,是没有办法删除的,因为这个目录有可能其他容器在使用,同时还有可能没有权限删除外部的目录
测试
[root@docker-server3 ~]# docker run -d -v /data:/usr/share/nginx/html nginx:v1.5
8c5cd3b90c85c22a7e1d6847bd17fae9cef973d6d2e7a7327b6f35a18ebce8de
[root@docker-server3 ~]# docker rm -fv 8c5cd3b90c85
[root@docker-server3 ~]# ll /data/
自定义目录没有被删除
使用Dockerfile默认的挂载
[root@docker-server3 ~]# docker run -d nginx:v1.5
63710e4226db67455efe7831e27c4151d8e509624d32f97482f634aac1474c5e
[root@docker-server3 ~]# docker inspect 63710e4226db|grep Mounts -A 10
"Mounts": [
{
"Type": "volume",
"Name": "24dc1433bb9da5cf0739367e03cbdde2ed8a9db8ab320dee72cd3d8629a3d0cc",
"Source": "/var/lib/docker/volumes/24dc1433bb9da5cf0739367e03cbdde2ed8a9db8ab320dee72cd3d8629a3d0cc/_data", #默认挂载位置
"Destination": "/usr/share/nginx/html",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
[root@docker-server3 ~]# ll /var/lib/docker/volumes/24dc1433bb9da5cf0739367e03cbdde2ed8a9db8ab320dee72cd3d8629a3d0cc/_data
删除容器,但是不指定-v参数
[root@docker-server3 ~]# docker rm -f 63710e4226db
查看容器已经删除,目录还在
[root@docker-server3 ~]# docker ps -a
[root@docker-server3 ~]# ll /var/lib/docker/volumes/24dc1433bb9da5cf0739367e03cbdde2ed8a9db8ab320dee72cd3d8629a3d0cc/_data
重新创建容器,并使用-v参数删除
[root@docker-server3 ~]# docker run -d nginx:v1.5
5347b07f6d15245c17bbe92603a26a610be79788a6fddc1bf9d61eb7a138593b
[root@docker-server3 ~]# docker inspect 5347b07f6d15|grep Mounts -A 10
"Mounts": [
{
"Type": "volume",
"Name": "cc5c93a9923f719873695eecf7309c32d199831da4259ba7451100ccd6efe911",
"Source": "/var/lib/docker/volumes/cc5c93a9923f719873695eecf7309c32d199831da4259ba7451100ccd6efe911/_data",
"Destination": "/usr/share/nginx/html",
"Driver": "local",
"Mode": "",
"RW": true,
"Propagation": ""
}
[root@docker-server3 ~]# ll /var/lib/docker/volumes/cc5c93a9923f719873695eecf7309c32d199831da4259ba7451100ccd6efe911/_data
[root@docker-server3 ~]# docker rm -fv 5347b07f6d15
[root@docker-server3 ~]# ll /var/lib/docker/volumes/cc5c93a9923f719873695eecf7309c32d199831da4259ba7451100ccd6efe911/_data
ls: cannot access /var/lib/docker/volumes/cc5c93a9923f719873695eecf7309c32d199831da4259ba7451100ccd6efe911/_data: No such file or directory
使用-v参数,默认挂载的卷已经被删除
博主声明:本文的内容来源主要来自誉天教育晏威老师,由本人实验完成操作验证,需要的博友请联系誉天教育(http://www.yutianedu.com/),获得官方同意或者晏老师(https://www.cnblogs.com/breezey/)本人同意即可转载,谢谢!
DOCKER学习_014:Docker存储补充的更多相关文章
- Docker学习笔记 — Docker私有仓库搭建
Docker学习笔记 — Docker私有仓库搭建 目录(?)[-] 环境准备 搭建私有仓库 测试 管理仓库中的镜像 查询 删除 Registry V2 和Mavan的管理一样,Dockers ...
- Docker学习之Docker容器基本使用
Docker学习之Docker容器基本使用 新建容器并启动 命令格式:docker run --options repository:tag 后台运行 命令格式:-d 已存在的容器相关操作 启动:do ...
- Docker学习之Docker镜像基本使用
Docker学习之Docker镜像基本使用 获取镜像 命令格式:docker pull [选项] [Docker Registry 地址[:端口号]/]仓库名[:标签] 例如: docker pull ...
- DOCKER学习_006:Docker存储驱动
一 镜像的分层特性 在说docker的文件系统之前,我们需要先想清楚一个问题.我们知道docker的启动是依赖于image,docker在启动之前,需要先拉取image,然后启动.多个容器可以使用同一 ...
- Docker学习笔记 - Docker的守护进程
学习目标: 查看Docker守护进程的运行状态 启动.停止.重启Docker守护进程 Docker守护进程的启动选项 修改和查看Docker守护进程的启动选项 1.# 查看docker运行状态 方 ...
- Docker学习笔记 — Docker私有仓库搭建【转载】
标签: Docker 2015-03-10 21:08 24190人阅读 评论(0) 收藏 举报 分类: Docker(26) 目录(?)[+] 和Mavan的管理一样,Dockers不仅 ...
- Docker学习笔记 - Docker容器内部署redis
Docker学习笔记(2-4)Docker应用实验-redist server 和client的安装使用 一.获取redis容器(含客户端和服务端) 二.创建服务端容器 1.在终端A中运行redis- ...
- Docker学习笔记 - Docker客户端和服务端
学习内容: Docker客户端和服务端的通讯方式:client和自定义程序 Docker客户端和服务端的连接方式:socket 演示Docker客户端和服务端之间用remote-api通讯:nc ...
- Docker 学习2 Docker基础用法
一.docker架构 1.client端 2.server端,docker daemo守护进程,监听在套接字之上.docker支持三种类型套接字. a.ip vs套接字:即IP + 端口套接字 b.i ...
随机推荐
- 201871030139-于泽浩 实验二 个人项目D{0-1} KP
201871030139-于泽浩 实验二 个人项目D{0-1} KP 项目 内容 课程班级博客连接 2018级卓越班 这个作业要求连接 软件工程个人项目 我的课程学习目标 (1)掌握软件项目个人开发流 ...
- Windows Service 2016 Datacenter\Stand\Embedded激活方法
安装好系统后连入互联网之后使用管理员身份打开命令行 输入命令 slmgr /skms kms.03k.org 弹出窗口提示模式修改成功后再输入命令:slmgr /ato 以下为各个版本的key 版本: ...
- 记一次踩坑之路之Ubuntu未导入镜像前配置docke/docker-composer
更新 apt 包索引与升级 sudo apt-get update sudo apt-get upgrade 安装 apt 依赖包,用于通过HTTPS来获取仓库: sudo apt-get insta ...
- Leedcode算法专题训练(分治法)
归并排序就是一个用分治法的经典例子,这里我用它来举例描述一下上面的步骤: 1.归并排序首先把原问题拆分成2个规模更小的子问题. 2.递归地求解子问题,当子问题规模足够小时,可以一下子解决它.在这个例子 ...
- 网络编程之BIO和NIO
目录 OSI网络七层模型 TCP/UDP协议 TCP消息头 TCP三次握手.四次挥手 UDP协议 TCP协议/UDP协议区别 HTTP协议 HTTP协议请求头 HTTP协议响应头 HTTP状态码 so ...
- Day01_06_Java注释
Java注释 注释 - 单行注释:// xxxxx - 多行注释:/* xxxxx */ - javadoc注释: /** * * * */ - javadoc注释可以被bin目录下的javadoc. ...
- Day07_38_集合中的remove()方法
集合中的remove()方法 remove() 移除集合中的一个指定对象 代码实例 package com.shige.Collection; import java.util.ArrayList; ...
- 痞子衡嵌入式:利用i.MXRT1xxx系列内部DCP引擎计算Hash值时需特别处理L1 D-Cache
大家好,我是痞子衡,是正经搞技术的痞子.今天痞子衡给大家介绍的是利用i.MXRT1xxx系列内部DCP引擎计算Hash值时需特别处理L1 D-Cache. 关于i.MXRT1xxx系列内部通用数据协处 ...
- 硬件篇-02-TX2刷机Jetpack4.3
Jetson TX2收货将近一周了,期间趁摄像头还没到,预先给TX2配置了环境.由于学校要求写毕设日志,故干脆一起在知乎写了,顺带帮助想要给TX2配环境却苦于网络上关于TX2的教程很少的同学. 本期内 ...
- SSDT表结构的深入学习
SSDT表的知识目录: A.了解SSDT结构 B.由SSDT索引号获取当前函数地址 C.如何获取索引号 D.获取起源地址-判断SSDT是否被HOOK E.如何向内核地址写入自己代码 A. ...