我有docker-compose.yml
这样:
version: '3'
services:
mysql:
image: mysql
volumes:
- data:/var/lib/mysql
environment:
- MYSQL_ROOT_PASSWORD=$ROOT_PASSWORD
volumes:
data:
我的挂载点看起来像:/var/lib/docker/volumes/some_app/_data
我想从该挂载点访问数据,我不知道如何在Windows机器上执行此操作。也许我可以创建一些额外的容器,可以将数据从docker虚拟机传递到我的目录?
当我安装这样的文件夹时:
volumes:
- ./data:/var/lib/mysql
使用我的本地目录 - 由于权限问题我没有成功。并且读到“正确的方式”正在使用泊坞窗卷。
UPD:MySQL容器就是一个例子。我想对我的代码库使用这种行为,并使用docker foe本地开发。
答案 0 :(得分:8)
对于Windows下的Linux容器,docker通过Linux虚拟机运行实际,因此您的named
卷是该VM中本地目录到容器中目录的映射。
所以你得到的/var/lib/docker/volumes/some_app/_data
是该VM内的一个目录。要检查它,您可以:
docker run --rm -it -v /:/vm-root alpine:edge ls -l /vm-root/var/lib/docker/volumes/some_app/_data
total 188476
-rw-r----- 1 999 ping 56 Jun 4 04:49 auto.cnf
-rw------- 1 999 ping 1675 Jun 4 04:49 ca-key.pem
-rw-r--r-- 1 999 ping 1074 Jun 4 04:49 ca.pem
-rw-r--r-- 1 999 ping 1078 Jun 4 04:49 client-cert.pem
-rw------- 1 999 ping 1679 Jun 4 04:49 client-key.pem
-rw-r----- 1 999 ping 1321 Jun 4 04:50 ib_buffer_pool
-rw-r----- 1 999 ping 50331648 Jun 4 04:50 ib_logfile0
-rw-r----- 1 999 ping 50331648 Jun 4 04:49 ib_logfile1
-rw-r----- 1 999 ping 79691776 Jun 4 04:50 ibdata1
-rw-r----- 1 999 ping 12582912 Jun 4 04:50 ibtmp1
drwxr-x--- 2 999 ping 4096 Jun 4 04:49 mysql
drwxr-x--- 2 999 ping 4096 Jun 4 04:49 performance_schema
-rw------- 1 999 ping 1679 Jun 4 04:49 private_key.pem
-rw-r--r-- 1 999 ping 451 Jun 4 04:49 public_key.pem
-rw-r--r-- 1 999 ping 1078 Jun 4 04:49 server-cert.pem
-rw------- 1 999 ping 1675 Jun 4 04:49 server-key.pem
drwxr-x--- 2 999 ping 12288 Jun 4 04:49 sys
运行一个辅助容器,它已将该VM /
的孔根文件系统安装到容器目录/vm-root
中。
要使某个文件在后台使用某个命令运行容器(在我的情况下为tail -f /dev/null
),那么您可以使用docker cp
:
docker run --name volume-holder -d -it -v /:/vm-root alpine:edge tail -f /dev/null
docker cp volume-holder:/vm-root/var/lib/docker/volumes/volumes_data/_data/public_key.pem .
如果您想要一个透明的SSH到该VM,从2017年6月起,它似乎尚不支持。 Here码头工作人员说。{/ p>