Docker 学习笔记(三):数据、网络、系统权限、docker-compose
一、Docker 数据管理
Docker 持久化数据有两种方式:
- 使用数据卷:更安全,和主机耦合度低
 - 将主机的目录挂载到容器中:更方便,主机和容器可以很方便地交换数据。
 
数据卷相关的命令:
docker volume create <volume name>  # 新建数据卷
docker volume ls  # 列出所有数据卷
docker volume inspect <volume name>  # 查看数据卷信息
docker volume rm <volume name>  # 删除数据卷
docker volume prune  # 清除所有未挂载的数据卷
数据卷/文件夹的挂载命令:
# 1. 挂载数据卷
docker run -d -P \
    --name web \
    # -v my-vol:/wepapp \
    --mount source=my-vol,target=/webapp \
    training/webapp \
    python app.py
# 2. 挂载宿主机的文件夹
docker run -d -P \
    --name web \
    # -v /src/webapp:/opt/webapp:ro \
    --mount type=bind,source=/src/webapp,target=/opt/webapp,readonly \
    training/webapp \
    python app.py
# P.S. 以前是使用 -v 参数,现在推荐使用 --mount
数据卷的备份恢复
数据卷的备份、恢复与内容查看,都必须通过容器进行!
官方的推荐方法是,启动一个中间容器,挂载上对应的数据卷。
然后进入该容器查看数据卷内容,使用 tar 命令进行数据卷内容的备份(打包成 tar.gz)/恢复(将 tar.gz 解压到数据卷中)。
二、网络
1. 外部访问容器
使用端口映射 -p <宿主机端口>:<容器端口>(该参数可重复多次使用),或者 -P 将容器 EXPOSE 出来的端口随机映射到宿主机。
2. 容器之间的互联
比较方便的方案,是将容器加入自定义的 Docker 网络以实现多容器互联。
新建自定义网络
docker network create --driver=bridge <net name> # 新建自定义网络,使用 bridge 模式
在运行容器时,通过
docker run --network=<net name> --name <container name> ...将容器添加到该自定义网络
然后在其中一个容器中ping <container name>,该名称会直接被解析到对应的容器 ip。这样,容器之间就能以容器名称为 hostname 互联。通过
docker container inspect可获知容器在 docker0 上的 ip 地址,容器之间可以通过该 ip 通信。- 缺点:ip 是动态分配的!每次都要手动配。。
 
如果容器较多,推荐使用 docker-compose 进行编排。
3. 容器访问宿主机网络
从 Docker 对这种连接方式的支持来看,显然是很不推荐用户这么干的。
但是对个人用户而言,从容器访问宿主机,我觉得还是个挺常见的需求。
可用方法如下:
- 通过宿主机的公网 ip 访问宿主机
- 缺点:宿主机需要向公网开放对应的端口。
 
 - 在运行容器时指定 
--network=host,容器与宿主机共用网络- 缺点:容器与宿主机耦合度过高。而且可能出现端口冲突。
 
 - 通过 
ip addr show docker0查看宿主机在网桥docker0上的 ip 地址(linux 下一般为172.17.0.1),容器可通过该 ip 访问宿主机。- 缺点:不同宿主机在 
docker0上可能具有不同的 ip,需要运行时手动配置。 
 - 缺点:不同宿主机在 
 - 通过 shell 脚本获取 host ip:参见 Docker for Linux - Support host.docker.internal DNS name to host
 - 等 special DNS record for host.docker.internal + gateway.docker.internal 被 merged,就能直接使用 
host.docker.internal访问宿主机了。 
三、使用 nsenter 进入容器的网络 namespace
查看 Docker 容器的连接数:
docker inspect -f '{{.State.Pid}}' <containerid>  # 查找到容器的 pid
sudo nsenter -t <pid> -n netstat | grep ESTABLISHED  # 通过 pid 检索所有连接
三、系统权限
一个系统上的 docker 容器,默认情况下是无法修改系统的公共内核参数的。这是一种隔离机制。
如果某个容器抽风把系统参数改得一团糟,那所有容器都会崩溃,没有人会希望碰到这种情况。
但是有的时候,我们确实需要在容器内修改整个系统的某些参数。比如在测试系统的时候,我们系统直接修改整个系统的时间,然后查看我们的应用能否应对这种问题。
为了满足这种需求,Docker 提供了一组参数用来给容器设置额外的权限。
Docker 容器的隔离是基于 Linux 的 Capability 机制实现的, Linux 的Capability 机制允许你将超级用户相关的高级权限划分成为不同的小单元. 目前 Docker 容器默认只用到了以下的 Capability:
CHOWN,
DAC_OVERRIDE,
FSETID,
FOWNER,
MKNOD,
NET_RAW,
SETGID,
SETUID,
SETFCAP,
SETPCAP,
NET_BIND_SERVICE,
SYS_CHROOT,
KILL,
AUDIT_WRITE
使用 --cap-add, --cap-drop 可以添加或禁用特定的权限。
比如容器若要修改系统时间,就要求它拥有 SYS_TIME 权限,所以我们在运行容器时需要添加参数 --cap-add SYS_TIME。
然后在容器里运行 date --set "time-string",就能修改掉整个系统的时间。
P.S.
--privileged参数也可以达到开放权限的作用, 与--cap-add的区别就是,--privileged是将所有权限给容器,这相当危险!
四、docker-compose
用于编排多个容器,管理容器集群之间的协作关系。
国内安装镜像:docker: install-compose
常用命令
docker-compose up:- (推荐在测试时使用)新建并启动容器,聚合输出容器组中所有容器的 logs,命令结束时(ctrl+c),会 stop 掉整个容器组。
 - (在生产环境下要添加该选项!)在 
-d模式(detached,分离模式)下运行。与默认行为的差别在与,命令结束后,容器组中的容器仍然会继续运行。 
docker-compose start: 启动终止的容器组。
docker-compose 大部分命令都和 docker 完全类似。只是它是集群版本。
docker-compose.yml 模板
参考
Docker 学习笔记(三):数据、网络、系统权限、docker-compose的更多相关文章
- Docker学习笔记二(linux下安装Docker)
		
Docker学习笔记二(linux下安装Docker) 1.在线安装linux Docker 这种方式首先要保证linux 环境下可以上网,当然,小编是在自己的电脑上安装了虚拟机,在虚拟机上安装了,l ...
 - Docker学习笔记之-在CentOS中安装Docker
		
上一节演示了如何 通过Xshell连接CentOS服务,链接:Docker学习笔记之-通过Xshell连接 CentOS服务 本节将演示 如何在CentOS中安装 Docker 第一步:更新系统包到最 ...
 - Docker学习笔记三:Docker部署Java web系统
		
Docker部署Java Web系统 1.在root目录下创建一个路径test/app mkdir test && cd test&& mkdir app && ...
 - Docker学习笔记三
		
4.Docker数据管理 4.1.数据卷 数据卷是一个可供容器使用的特殊目录,它将主机操作系统目录直接映射进容器,类似与Linux的mount行为. 特性: 数据卷可以在容器之间共事和重用,容器间传递 ...
 - Docker学习笔记1:CentOS7 下安装Docker
		
本文内容摘自官网:https://docs.docker.com/engine/installation/linux/centos/#/create-a-docker-group 注:本文是介绍Lin ...
 - docker学习笔记:简单构建Dockerfile【Docker for Windows】
		
参考与入门推荐:https://www.cnblogs.com/ECJTUACM-873284962/p/9789130.html#autoid-0-0-9 最近学习docker,写一个简单构建Doc ...
 - docker学习笔记1-- 用Toolbox安装Docker--介绍Docker Machine
		
使用的是Docker Toolbox,非Docker for Windows 一.docker的认识与安装(windows安装) http://blog.csdn.net/tina_ttl/artic ...
 - docker学习 (三)  Windows 10 安装Docker
		
Docker CE: 社区版,免费. Docker EE: 企业版,收费. 安装: Windows 10 Pro 64, 必须开启Hyper-v 下载:Docker for W ...
 - Docker学习笔记三 Dockerfile 指令 定制镜像
		
本文地址:https://www.cnblogs.com/veinyin/p/10412079.html 镜像是分层存储的,每一层都是独立存在的,修改当前层并不会修改其依赖的上一层,删除某一层也只是 ...
 - SpringMVC 学习笔记(三)数据的校验
		
34. 尚硅谷_佟刚_SpringMVC_数据绑定流程分析.avi 例如:在jsp中输入一个String字符串类型,需要转换成Date类型的流程如下 convertservice对传入的数据进行转换 ...
 
随机推荐
- qt 应用程序版本设置方法
			
pro 增加 VERSION = 1.2.3.4 DEFINES += APP_VERSION=\\\"$$VERSION\\\" 应用程序中用 APP_VERSION 宏就可以获 ...
 - oracle导入提示“IMP-00010:不是有效的导出文件,头部验证失败”的解决方案
			
这是由于导出的dmp文件与导入的数据库的版本不同造成的用Notepad++查看了dmp文件,在头部具修改成你将导入目标数据库的版本号以下对应的版本号: 11g R2:V11.02.00 11g R1: ...
 - Android通过ksoap2这个框架调用webservice大讲堂
			
昨天有人问我Android怎么连接mysql数据库,和对数据库的操作呀,我想把,给他说说json通信,可是他并不知道怎么弄,哎算了吧,直接叫他用ksoap吧,给他说了大半天,好多零碎的知识,看来还是有 ...
 - 将移远通信的EC20驱动移植到NUC972上(转)
			
源: 将移远通信的EC20驱动移植到NUC972上
 - 使用AWS Lambda,API Gateway和S3 Storage快速调整图片大小
			
https://www.obytes.com/blog/2019/image-resizing-on-the-fly-with-aws-lambda,-api-gateway,-and-s3-stor ...
 - vs 设置护眼背景颜色
			
工具 —> 选项 —> 环境 —> 字体和颜色 —> 纯文本(显示项中) —> 项目背景 —> 自定义—> 色调位85.饱和度123.亮度205,保存即可.测 ...
 - centos7.6_x86_64使用Squid搭建代理服务器让windows上网
			
centos7.6_x86_64使用Squid搭建代理服务器让windows上网 windows机器很多站点访问受限,可以在没有限制外网的机器上面搭建代理服务器,其它电脑可以配置代理通过这台不受限制的 ...
 - svn服务端搭建
			
本文介绍的是SVN的服务器端的搭建. 一.SVN服务器安装 1. 首先来下载和搭建SVN服务器,下载地址如下: http://subversion.apache.org/packages.ht ...
 - 手机wifi连上Fiddler后无网络问题解决
			
早上老板交代一个任务,对一款app抓包分析下接口调用的时延.我的重新打开了一年多前用过的Fiddler(参见win10笔记本用Fiddler对手机App抓包),拿过测试手机开始设置wifi代理地址和端 ...
 - ubuntu 防火墙打开关闭
			
1.查看防火墙状态 sudo ufw status 2.打开防火墙 sudo ufw enable 3.关闭防火墙 sudo ufw disable