设为首页 收藏本站
查看: 1032|回复: 0

[经验分享] Docker数据管理、网络通信以及资源控制

[复制链接]

尚未签到

发表于 2019-2-21 08:02:00 | 显示全部楼层 |阅读模式
  Docker的安装及镜像、容器的基本操作详见博客http://blog.运维网.com/11134648/2160257
下面介绍Docker数据管理、网络通信以及资源控制的方法,详细如下:

Doker数据管理
  容器的数据管理操作可以方便查看容器内产生的数据或者将多个容器中的数据实现共享。管理Docker容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(Data Volumes Containers)。

一、数据卷
  数据卷是一个供容器使用的特殊目录,位于容器中,可将宿主机的目录挂载到数据卷上,实现数据在宿主机与容器之间的迁移。

1.下载镜像centos

docker pull centos
2.创建数据卷

#使用centos镜像创建一个名为web1的容器,并且创建两个数据卷分别挂载到/data1与/data2目录上
docker run -d -v /data1 -v /data2 --name web1 -it centos /bin/bash




  • -i : 让容器对的输入保持打开
  • -t : 让Docker分配一个伪终端
  • -d : 让docker以守护形式在后台运行


3.进入容器查看/data1与/data2目录

docker exec -it web1 /bin/bash
ls -l


4.挂载主机目录作为数据卷

#使用centos镜像创建一个名为web2的容器,将宿主机的/var/www目录挂载到容器的/data1目录
docker run -d -v /var/www:/data1 --name web2 -it centos /bin/bash

注意:宿主机本地目录的路径必须使用绝对路径,如果路径不存在,Docker会自动创建相应的路径。


5.在宿主机的/var/www目录下创建一个文件file

cd /var/www
touch file
ls


6.进入运行着的容器中,到相应挂载目录/data1目录下查看

docker exec -it web2 /bin/bash
cd /data1
ls

实现了从宿主机到容器的数据迁移。


二、数据卷容器
  数据卷容器就是一个普通容器,专门提供数据卷给其他容器挂载使用。实现在容器之间共享一些数据。

1.创建一个容器作为数据卷容器
  使用前面创建好的数据卷容器web1

2.使用--volumes-from来挂载web1容器中的数据卷到新的容器,新的容器名为db1

docker run -it --volumes-from web1 --name db1 centos /bin/bash
ls


3.在db1容器的数据卷/data2目录下创建一个文件file

cd /data2
touch file
ls


4.在web1容器中的/data2目录中查看创建的file文件

docker exec -it web1 /bin/bash
cd /data2
ls

这样就可以通过数据卷容器实现容器之间的数据共享。


Docker网络通信
  Docker提供了映射端口到宿主机和容器互联机制来为容器提供网络服务。

一、端口映射
  Docker提供端口映射机制来将容器内的服务提供给外部网络访问,实质上就是提供将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可访问容器内的服务。

#方法一:
命令格式: docker run -d -P 镜像名称
其中-P(大写)选项实现随机映射
#方法二:
命令格式: docker run -d -p 宿主机的端口号:容器内的端口号 镜像名称
其中-p(小写)选项指定要映射的端口
  例如访问容器内的httpd服务

1.端口随机映射

docker run -d -P httpd:centos   #随机映射
  使用docker ps -a命令查看端口的映射


2.指定端口映射

docker run -d -p 49280:80 httpd:centos #指定端口映射
  使用docker ps -a命令查看端口的映射


二、容器互联
  容器互联是通过容器的名称在容器键建立一条专门的网络通信隧道从而实现容器的互联。简单点说,就是在源容器和接收容器间建立一条隧道,接收容器可以看到源容器指定的信息。

格式为--link name:alias
其中name是要连接的容器名称,alias是这个连接的别名
1.创建源容器
  使用docker命令建立容器A,使用--name指定容器名称为test1.

docker run -itd -P --name test1  centos  /bin/bash


2.创建接收容器
  使用docker run命令建立容器B,使用--name指定容器名称为test2,使用--link指定连接容器以实现容器互联。

docker run -itd  -P --name test2 --link test1:test1 centos  /bin/bash


3.测试容器互联
  进入接收容器,使用ping命令查看是否能连通。

docker exec -it test2 /bin/bash
ping test1


Docker资源控制
  Docker是使用Cgroup机制进行管理的,Cgroup是Control group的简写,是Linux内核提供的一种限制所使用物理资源机制,这些资源主要包括CPU、内存、blkio.

一、对CPU的控制

1.限制CPU的使用速率
  --cpu-quota选项限制CPU的使用率,CPU的百分比是以1000为单位的。

docker run --cpu-quota 20000 centos(容器名)    #cpu的使用率限定为20%
2.多任务按比例分享CPU
  --cpu-shares设置CPU按比例共享CPU资源

docker run --cpu-shares 1024 容器A
docker run --cpu-shares 1024 容器B
docker run --cpu-shares 1024 容器C
3.限制CPU内核使用
  --cpuset-cpus使某些程序独享CPU内核,以便提高其处理速度

docker run --cpuset-cpus 0,1 容器名       #容器独享 第1和第2个内核
二、对内存使用的限制
  docker run -m命令限制容器内存使用量。

docker run -m 512m 容器名      #限制容器内存512M
三、对blkio的限制
  在一台服务器上进行容器的混合部署,会出现同时有几个程序写磁盘数据的情况,可以通过--device-write-bps选项限制写入的ipos,相应的还有--device-read-bps选项限制读取的ipos。但是这个方法只能针对blkio限制的是设备,而不是分区。
  例如限制容器的/dev/sda1的写入ipos为1MB

docker run --device-write-bps /dev/sda1:1mb 容器名



运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-675070-1-1.html 上篇帖子: Docker创建镜像以及私有仓库 下篇帖子: 【Docker篇之三】Dockerfile创建镜像
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表