docker高级应用之动态绑定卷组

之前介绍过docker高级应用之动态扩展容器空间大小(地址:http://dl528888.blog.51cto.com/2382721/1606170),本次介绍如何动态的绑定卷组。

为什么使用卷组呢,比如想把物理机里的目录给予容器共享,或者把物理机的一个目录作为共享目录,做日志搜集等等功能。

默认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

下面是做绑定测试

[email protected]:/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
[email protected]:/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
[email protected]:/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)
[email protected]:/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 </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里内容是

[email protected]:/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

挂载的方法是

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

第一个参数是容器名,第二个参数的物理机的目录,第三个参数是挂载到容器里的目录

进行挂载

[email protected]:/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!

可以看到成功的挂载了

下面做一下测试

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
[email protected]:/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)
[email protected]:/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

可以看到已经动态的挂在上了,并且挂在后目录里的内容一致

如果挂载的时候,第一个参数,容器不存在会报以下错误

16:23:27 # sh dynamic_mount_docker_volume.sh  test123 /data/docker-dir/ /src
Error: No such image or container: test123

如果挂载的时候,第二个参数,物理机的被挂载的目录不存在,会报错

[email protected]:/tmp
15:39:18 # sh dynamic_mount_docker_volume.sh  test /tmp/sfsdfdf1 /src
physics /tmp/sfsdfdf1 is not exist!

如果挂载的时候,第三个参数,容器的挂载的目录已经被挂载了,会报错

15:44:25 # sh dynamic_mount_docker_volume.sh  test /data/software/ /src
container test mount dir /src is mounting!

上面就是介绍如何动态的绑定卷组,只是一种方法,不太建议使用,有问题请留言。

时间: 2024-12-22 07:17:13

docker高级应用之动态绑定卷组的相关文章

AIX 5L 系统管理技术 —— 存储管理——卷组

卷组 在安装系统时,就会创建一个rootvg卷组.包含自带硬盘(内置硬盘)和系统逻辑卷,一个系统只能有一个rootvg卷组.一般情况下rootvg卷组最好只包含自带硬盘. 一.创建卷组 在创建卷组之前,系统管理员必须知道如下所列的信息. (1)卷组的名字在系统中必须是唯一的.卷组名要求时一个字符串,长度时1至15字符. (2)要确定新卷组中包含哪些物理卷,并保证这些物理卷再系统中是可用状态,而且没有被其他卷组使用.要能知道这些物理卷的名称. (3)确定新卷组中的物理分区大小,它的范围时1到102

逻辑卷在卷组中不显示

问题: 昨天创建的逻辑卷,今天在卷组目录里没有找到 逻辑卷还是是存在的,并且存在于对应的卷组目录,如下所示: [[email protected] dev]# lvdisplay | grep lvf216   LV Path                /dev/vgf/lvf216  LV Name                lvf216 但是卷组里并没有想要的逻辑卷,如下所示: [[email protected] vgf]# raw /dev/raw/raw344 /dev/vgf

物理卷操作命令:pvcreate,pvscan,pvdisplay.卷组操作命令:vgcreate,vgdisplay.

新硬盘创建LVM系统过程. 物理卷操作命令:pvcreate,pvscan,pvdisplay. 卷组操作命令:vgcreate,vgdisplay. 逻辑卷操作命令:lvcreate,lvdisplay. Linx卷管理详解 VG LV PV 作者:吴伟龙 一. 前言 每个Linux使用者在安装Linux时 都会遇到这样的困境:在为系统分区时,如何精确评估和分配各个硬盘分区的容量,因为系统管理员不但要考虑到当前某个分区需要的容量,还要预见该分区以后可能需要的容量的最大值.因为如果估计不准确,当

Linux下 扩展逻辑分区和扩展逻辑卷组

开始我有个小误区,一时没有想通现在写出来,希望以后不会再犯. 练习之前,我首先添加了一块10G的硬盘,然后将该盘分区:如下 fdisk /dev/sdb  n p 4 t 8e w pvcreate /dev/sdb4 pvdisplay vgcreate  VG01  /dev/sdb4 vgdisplay lvcreate -L 100M -n lvdata1  VG01 mkfs -t ext3 /dev/VG01/lvdata1 注意关键是这里的100M,本来是10G的硬盘,我一开只划分

物理卷操作命令:pvcreate,pvscan,pvdisplay.卷组操作命令:vgcreate,vgdisplay. (转)

新硬盘创建LVM系统过程. 物理卷操作命令:pvcreate,pvscan,pvdisplay. 卷组操作命令:vgcreate,vgdisplay. 逻辑卷操作命令:lvcreate,lvdisplay. Linx卷管理详解 VG LV PV 作者:吴伟龙 一. 前言 每个Linux使用者在安装Linux时 都会遇到这样的困境:在为系统分区时,如何精确评估和分配各个硬盘分区的容量,因为系统管理员不但要考虑到当前某个分区需要的容量,还要预见该分区以后可能需要的容量的最大值.因为如果估计不准确,当

GNU/Linux下LVM配置管理以及快照卷、物理卷、卷组、逻辑卷的创建和删除

LVM是Linux环境中对磁盘分区进行管理的一种机制,是建立在硬盘和分区之上.文件系统之下的一个逻辑层,可提高磁盘分区管理的灵活性.最大的优点是在不损伤数据的前提下调整存储空间的大小. 本篇主要讲述LVM的创建.LVM的扩展与缩减和快照卷的使用三部分 第一部分:LVM的创建 LVM创建的大致步骤为 1.将多个分区转化为多个物理卷PV(Physical Vomule)    一个分区可以创建一个物理卷,可以在多块磁盘上创建物理卷.也可以做raid10磁盘阵列以后在做物理卷, 以    便有更快的读

18.文件系统——扩展、缩减卷组和逻辑卷以及创建快照卷、移除卷

一.扩展卷组 扩展卷组相对简单,只需要添加一个物理卷即可,使用的命令是vgextend,其格式为: vgextend VG_NAME /PATH/TO/PV 下面来演示一下扩展卷组的过程: 1. 首先准备一块id号位8e的分区,具体过程见前文. [[email protected] ~]# fdisk/dev/sdc WARNING: DOS-compatible mode is deprecated. It's stronglyrecommended to          switch of

LVM逻辑卷VG卷组丢失故障处理

LVM是通过将物理的磁盘或磁盘分区创建成物理卷(PV),多个物理卷添加创建为一个卷组(VG),然后在卷组的基础上创建逻辑卷(LVM),进而在逻辑卷上去创建文件系统,这种在硬盘或分区和文件系统之下的磁盘管理机制大大提高了对磁盘管理的灵活性,也是当前企业Linux环境下实现对磁盘分区管理的方式.但在实际应用管理中,常常因为误操作,系统断电等原因造成卷组丢失,逻辑卷无法挂载等异常的故障,本文将通过在企业运维实践中逻辑卷故障处理过程给大家分享因为断电原因造成卷组丢失的恢复方法. 问题现象系统重启后,发现

Open-E DSS V7 应用系列之七 卷组和卷的管理

续Open-E DSS V7 应用系列之六 构建软件iSCSI 一.基本介绍 单元(Units):物理硬盘或者RAID阵列. DSS用S0,S1, ..., S[x] 代表 SATA / JBOD / RAID单元,用H0,H1, ..., H[x] 代表IDE单元,用MD0,MD1, ..., MD[x]代表软件RAIDs. 可以在一个UNIT建立卷组,也可以将一个新单元添加到一个已存在的卷组. DSS只能允许管理至少大于5G的UNITS. 卷组(Volume Group):由一个或者多个单元