docker高级应用之动态绑定卷组
之前介绍过docker高级应用之动态扩展容器空间大小(地址:http://dl528888.blog.51cto.com/2382721/1606170),本次介绍如何动态的绑定卷组。
为什么使用卷组呢,比如想把物理机里的目录给予容器共享,或者把物理机的一个目录作为共享目录,做日志搜集等等功能。
默认docker添加卷组是在启动容器的使用使用-v参数
1 | - v , --volume=[] Bind mount a volume (e.g., from the host: - v /host : /container , from docker: - v /container ) |
举例
物理机目录/data/software想挂载到容器的/tmp/software里
其中/data/software内容是
1 2 3 4 5 6 | 15:21:14 # ll /data/software/ total 19692 -rw-r--r-- 1 root root 1940 Nov 10 20:42 CentOS-Base-6.repo -rwxr-xr-x 1 root root 12752168 Nov 10 14:15 etcd -rwxr-xr-x 1 root root 7400424 Nov 10 14:15 etcdctl drwxr-xr-x 21 1000 1000 4096 Oct 29 02:06 systemd-217 |
启动docker的命令是
1 | docker run -d -p 22 --name= "test" - v /data/software : /tmp/software docker.ops-chukong.com:5000 /centos6-http :new /usr/bin/supervisord |
下面是做绑定测试
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 | root@docker-test2: /tmp 15:29:23 # docker run -d -p 22 --name="test" -v /data/software:/tmp/software docker.ops-chukong.com:5000/centos6-http:new /usr/bin/supervisord a21506d7b36e04e091008f4a326ac17c94e3d855e3aadb52992d7ba95f45cbbf root@docker-test2: /tmp 15:31:15 # docker-enter test sh -c "ls -l /tmp/software" total 19692 -rw-r--r-- 1 root root 1940 Nov 10 20:42 CentOS-Base-6.repo -rwxr-xr-x 1 root root 12752168 Nov 10 14:15 etcd -rwxr-xr-x 1 root root 7400424 Nov 10 14:15 etcdctl drwxr-xr-x 21 1000 1000 4096 Oct 29 02:06 systemd-217 root@docker-test2: /tmp 15:31:21 # docker-enter test sh -c "mount" rootfs on / type rootfs (rw) /dev/mapper/docker-8 :17-37748738-a21506d7b36e04e091008f4a326ac17c94e3d855e3aadb52992d7ba95f45cbbf on / type ext4 (rw,relatime,discard,stripe=16,data=ordered) proc on /proc type proc (rw,nosuid,nodev,noexec,relatime) sysfs on /sys type sysfs (rw,nosuid,nodev,noexec,relatime) shm on /dev/shm type tmpfs (rw,nosuid,nodev,noexec,relatime,size=65536k) /dev/sdb1 on /.dockerinit type ext4 (rw,relatime,data=ordered) /dev/sda3 on /etc/resolv .conf type ext4 (rw,relatime,data=ordered) /dev/sdb1 on /etc/hostname type ext4 (rw,relatime,data=ordered) /dev/sdb1 on /etc/hosts type ext4 (rw,relatime,data=ordered) /dev/sda3 on /tmp/software type ext4 (rw,relatime,data=ordered) /dev/sdb1 on /.dockerenv type ext4 (rw,relatime,data=ordered) devpts on /dev/tty1 type devpts (rw,relatime,gid=5,mode=620,ptmxmode=000) devpts on /dev/pts type devpts (rw,relatime,gid=5,mode=620,ptmxmode=666) devpts on /dev/ptmx type devpts (rw,relatime,gid=5,mode=620,ptmxmode=666) root@docker-test2: /tmp 15:31:28 # docker-enter test sh -c "df -h" Filesystem Size Used Avail Use% Mounted on rootfs 9.8G 470M 8.8G 5% / /dev/mapper/docker-8 :17-37748738-a21506d7b36e04e091008f4a326ac17c94e3d855e3aadb52992d7ba95f45cbbf 9.8G 470M 8.8G 5% / shm 64M 0 64M 0% /dev/shm /dev/sdb1 1.8T 22G 1.7T 2% /.dockerinit /dev/sda3 518G 457G 35G 93% /etc/resolv .conf /dev/sdb1 1.8T 22G 1.7T 2% /etc/hostname /dev/sdb1 1.8T 22G 1.7T 2% /etc/hosts /dev/sda3 518G 457G 35G 93% /tmp/software /dev/sdb1 1.8T 22G 1.7T 2% /.dockerenv |
可以看到挂载完成,并且容器里的/tmp/software与/data/software里内容一致
但上面只是在创建并启动容器的时候可以挂载卷组,如果允许中的如何挂载呢?
具体知识可以参考http://jpetazzo.github.io/2015/01/13/docker-mount-dynamic-volumes/
下面是修改的脚本
内容为
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 | #!/bin/bash #This script is dynamic mount docker volumens #Author Deng Lei if [ -z $1 ] || [ -z $2 ] || [ -z $3 ]; then echo "Usage: container_name physics_volumes container_volumes" echo "Example: I want mount physics /tmp/test to container /src in test" echo "The command is: bash `basename $0` test /tmp/test /src " exit 1 fi which nsenter &>> /dev/null if [ $? - ne 0 ]; then echo "plsease install nsenser,command is:yum install util-linux" exit 1 fi set -e CONTAINER=$1 HOSTPATH=$2 CONTPATH=$3 if [ ! -d $HOSTPATH ]; then echo "physics $HOSTPATH is not exist!" exit 1 fi REALPATH=$(readlink --canonicalize $HOSTPATH) FILESYS=$( df -P $REALPATH | tail -n 1 | awk '{print $6}' ) while read DEV MOUNT JUNK do [ $MOUNT = $FILESYS ] && [ $DEV != "rootfs" ] && break done < /proc/mounts [ $MOUNT = $FILESYS ] # Sanity check! while read A B C SUBROOT MOUNT JUNK do [ $MOUNT = $FILESYS ] && break done < /proc/self/mountinfo [ $MOUNT = $FILESYS ] # Moar sanity check! SUBPATH=$( echo $REALPATH | sed s,^$FILESYS,,) DEVDEC=$( printf "%d %d" $(stat -- format "0x%t 0x%T" $DEV)) PID=$(docker inspect -- format "``.`State`.`Pid`" "$CONTAINER" ) run_command= "nsenter --target $PID --mount --uts --ipc --net --pid -- sh -c" if [ `$run_command "mount|grep $CONTPATH|wc -l" ` - ne 0 ]; then echo "container $CONTAINER mount dir $CONTPATH is mounting!" exit 1 fi $run_command "[ -b $DEV ] ||mknod --mode 0600 $DEV b $DEVDEC" $run_command "mkdir /tmpmnt" $run_command "mount $DEV /tmpmnt" $run_command "mkdir -p $CONTPATH" $run_command "mount -o bind /tmpmnt/$SUBROOT/$SUBPATH $CONTPATH" $run_command "umount /tmpmnt" $run_command "rmdir /tmpmnt" check_result=`$run_command "mount|grep $CONTPATH|wc -l" ` if [ $check_result - ne 0 ]; then echo "dymainc mount physics $HOSTPATH on $CONTAINER $CONTPATH is success!" else echo "dymaninc mount physics $HOSTPATH on $CONTAINER $CONTPATH is fail!" fi |
然后在给已经存在的test容器里新挂载一个卷组,把本地的/data/docker-dir挂载到/tmp/docker-dir
当前物理机/data/docker-dir里内容是
1 2 3 4 5 | root@docker-test2: /tmp 15:37:17 # ll /data/docker-dir/ total 4 -rw-r--r-- 1 root root 0 Feb 11 09:31 a -rw-r--r-- 1 root root 2 Feb 11 09:31 b |
挂载的方法是
1 2 3 4 | 15:38:28 # sh dynamic_mount_docker_volume.sh Usage: container_name physics_volumes container_volumes Example: I want mount physics /tmp/test to container /src in test The command is: bash dynamic_mount_docker_volume.sh test /tmp/test /src |
第一个参数是容器名,第二个参数的物理机的目录,第三个参数是挂载到容器里的目录
进行挂载
1 2 3 | root@docker-test2: /tmp 15:36:14 # sh dynamic_mount_docker_volume.sh test /data/docker-dir/ /tmp/docker-dir dymainc mount physics /data/docker-dir/ on test /tmp/docker-dir is success! |
可以看到成功的挂载了
下面做一下测试
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | 15:37:28 # docker-enter test sh -c "ls -l /tmp/docker-dir" total 4 -rw-r--r-- 1 root root 0 Feb 11 09:31 a -rw-r--r-- 1 root root 2 Feb 11 09:31 b root@docker-test2: /tmp 15:38:18 # docker-enter test sh -c "mount" rootfs on / type rootfs (rw) /dev/mapper/docker-8 :17-37748738-a21506d7b36e04e091008f4a326ac17c94e3d855e3aadb52992d7ba95f45cbbf on / type ext4 (rw,relatime,discard,stripe=16,data=ordered) proc on /proc type proc (rw,nosuid,nodev,noexec,relatime) sysfs on /sys type sysfs (rw,nosuid,nodev,noexec,relatime) shm on /dev/shm type tmpfs (rw,nosuid,nodev,noexec,relatime,size=65536k) /dev/sdb1 on /.dockerinit type ext4 (rw,relatime,data=ordered) /dev/sda3 on /etc/resolv .conf type ext4 (rw,relatime,data=ordered) /dev/sdb1 on /etc/hostname type ext4 (rw,relatime,data=ordered) /dev/sdb1 on /etc/hosts type ext4 (rw,relatime,data=ordered) /dev/sda3 on /tmp/software type ext4 (rw,relatime,data=ordered) /dev/sdb1 on /.dockerenv type ext4 (rw,relatime,data=ordered) devpts on /dev/tty1 type devpts (rw,relatime,gid=5,mode=620,ptmxmode=000) devpts on /dev/pts type devpts (rw,relatime,gid=5,mode=620,ptmxmode=666) devpts on /dev/ptmx type devpts (rw,relatime,gid=5,mode=620,ptmxmode=666) /dev/sda3 on /tmp/docker-dir type ext4 (rw,relatime,data=ordered) root@docker-test2: /tmp 15:38:24 # docker-enter test sh -c "df -h" Filesystem Size Used Avail Use% Mounted on rootfs 9.8G 470M 8.8G 5% / /dev/mapper/docker-8 :17-37748738-a21506d7b36e04e091008f4a326ac17c94e3d855e3aadb52992d7ba95f45cbbf 9.8G 470M 8.8G 5% / shm 64M 0 64M 0% /dev/shm /dev/sdb1 1.8T 22G 1.7T 2% /.dockerinit /dev/sda3 518G 457G 35G 93% /etc/resolv .conf /dev/sdb1 1.8T 22G 1.7T 2% /etc/hostname /dev/sdb1 1.8T 22G 1.7T 2% /etc/hosts /dev/sda3 518G 457G 35G 93% /tmp/software /dev/sdb1 1.8T 22G 1.7T 2% /.dockerenv /dev/sda3 518G 457G 35G 93% /tmp/docker-dir |
可以看到已经动态的挂在上了,并且挂在后目录里的内容一致
如果挂载的时候,第一个参数,容器不存在会报以下错误
1 2 | 16:23:27 # sh dynamic_mount_docker_volume.sh test123 /data/docker-dir/ /src Error: No such image or container: test123 |
如果挂载的时候,第二个参数,物理机的被挂载的目录不存在,会报错
1 2 3 | root@docker-test2: /tmp 15:39:18 # sh dynamic_mount_docker_volume.sh test /tmp/sfsdfdf1 /src physics /tmp/sfsdfdf1 is not exist! |
如果挂载的时候,第三个参数,容器的挂载的目录已经被挂载了,会报错
1 2 | 15:44:25 # sh dynamic_mount_docker_volume.sh test /data/software/ /src container test mount dir /src is mounting! |
上面就是介绍如何动态的绑定卷组,只是一种方法,不太建议使用,有问题请留言。
本文转自 reinxu 51CTO博客,原文链接:http://blog.51cto.com/dl528888/1613764,如需转载请自行联系原作者

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
docker高级应用之单机持久化固定容器IP
过完年了,快1个月没有写博客,现在给大家分享一下我是如何在单机环境,实现持久化固定容器IP。 我是去年6月份开始玩docker,到现在已经9个月了,docker的最新版本也到了1.5.目前我这里对docker已经放到测试环境给研发使用,目前感觉最大的问题就是容器手动重启或者异常关闭后在启动容器,那么容器的ip就回变化(这个是使用默认的docker0做桥接),如果使用pipework手动配置ip,也得重新在来一遍,很是麻烦,所以我写了一个程序来自动化的解决这个问题。 一、程序介绍 使用到的程序有2个: 1、创建容器程序,名字是create_docker_container_use_static_ip.sh,使用shell脚本编写。 2、监控容器状态并自动给重启没有ip的容器设置ip,名字是auto_check_modify_container.py,使用python编写。 创建容器程序的逻辑: 1、运行创建脚本来创建docker container; 2、创建的信息会写入到etcd里进行保存; 3、根据配置信息来创建具体的container。 其中我程序使用openvswitch来坐桥接...
- 下一篇
Spark的几种运行模式
应用场景 spark是基于内存计算的计算框架,性能很强悍,但是它支持单机模式,同时也支持集群模式,它的运行模式有好多种,为了不混淆方便区分,这里进行一些总结。网上总结了,多数为三种,四种,其实真实要细分,spark有六种运行模式,这里给出区分。 1. local模式【单机】 Local模式又称为本地模式,运行该模式非常简单,只需要把Spark的安装包解压后,改一些常用的配置即可使用,而不用启动Spark的Master、Worker守护进程( 只有集群的Standalone方式时,才需要这两个角色),也不用启动Hadoop的各服务(除非你要用到HDFS),这是和其他模式的区别。 运行实例 # ./bin/spark-submit --class org.apache.spark.examples.SparkPi --master local lib/spark-examples-1.0.0-hadoop2.2.0.jar # 注:看到 --master local 就可以确定是单机的local模式了! 这个SparkSubmit进程又当爹、又当妈,既是客户提交任务的Client进程、又是...
相关文章
文章评论
共有0条评论来说两句吧...