可以通过在容器内创建磁盘设备文件,然后把整个分区挂载进容器。
先看宿主的块设备:
$ lsblk
NAME MAJ:MIN RM SIZE RO TYPE MOUNTPOINT
sda 8:0 1 7.2G 0 disk
└─sda1 8:1 1 7.2G 0 part
nvme0n1 259:0 0 119.2G 0 disk
├─nvme0n1p1 259:1 0 260M 0 part /boot
├─nvme0n1p2 259:2 0 128M 0 part
├─nvme0n1p3 259:3 0 118G 0 part /
└─nvme0n1p4 259:4 0 850M 0 part
记下要挂载的分区的设备号(例如/的259:3)。
# 启动一个容器,没什么特殊参数
docker run -itd --name demo alpine:latest sh
#在容器内创建一个设备节点
$ docker exec demo mknod -m 0500 /dev/nvme0n1p3 b 259 3
# 找到容器PID=1的进程PID
$ docker top demo
UID PID PPID C STIME TTY TIME CMD
root 4189 4174 0 23:07 pts/0 00:00:00 sh
# 通过命名空间挂载磁盘
$ docker exec demo mkdir /data
$ sudo mount -N 4189 /dev/nvme0n1p3 /data
# 访问试试
$ docker exec demo ls -lh /data
total 16
-rw-r--r-- 1 root root 108 Jan 20 2019 archlinux
lrwxrwxrwx 1 root root 7 May 23 14:18 bin -> usr/bin
drwxr-xr-x 2 root root 6 Jan 20 2019 boot
...
分区都挂载进去了,干啥都行了~
弄完才发现和题主发的文章大同小异:-|