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

[经验分享] Docker高级应用之动态绑定卷组

[复制链接]

尚未签到

发表于 2015-12-25 08:28:22 | 显示全部楼层 |阅读模式
Docker高级应用之动态绑定卷组
[日期:2015-02-13]来源:Linux社区  作者:dl528888[字体:大 中 小]



之前介绍过Docker高级应用之动态扩展容器空间大小(地址:http://www.iyunv.com/Linux/2015-01/112245.htm),本次介绍如何动态的绑定卷组。
  为什么使用卷组呢,比如想把物理机里的目录给予容器共享,或者把物理机的一个目录作为共享目录,做日志搜集等等功能。
  默认docker添加卷组是在启动容器的使用使用-v参数
  -v, --volume=[]            Bind mount a volume (e.g., from the host: -v /host:/container, from docker: -v /container)
  举例
物理机目录/data/software想挂载到容器的/tmp/software里
其中/data/software内容是
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的命令是
  docker run -d -p 22  --name="test" -v /data/software:/tmp/software  docker.ops-chukong.com:5000/centos6-http:new /usr/bin/supervisord
  下面是做绑定测试
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/
下面是修改的脚本
内容为
#!/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

运维网声明 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-155917-1-1.html 上篇帖子: Docker 大规模应用部署管理方案 下篇帖子: DOCKER--没有普及的高大上
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

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

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

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

扫描微信二维码查看详情

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


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


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


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



合作伙伴: 青云cloud

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