如何在Docker容器内外互相拷贝数据

如何在Docker容器内外互相拷贝数据,第1张

1.用-v挂载主机数据卷到物兆容器

[plain] view plaincopy

docker run -v /path/to/hostdir:/mnt $container

在容器内拷贝

cp /mnt/sourcefile /path/to/destfile

2.直接在主机耐余上拷贝到容器物理存储系统

A. 获取容器名称或者id :

[plain] view plaincopy

$ docker ps

B. 获取整个容器的id

[plain] view plaincopy

$ docker inspect -f '{{.Id}}' 步骤A获取的名称或者id

C. 在主机上拷贝文件:

[plain] view plaincopy

$ sudo cp path-file-host /var/lib/docker/aufs/mnt/FULL_CONTAINER_ID/PATH-NEW-FILE

或者

$ sudo cp path-file-host /var/lib/docker/devicemapper/mnt/123abc<<id>>/rootfs/root

例子:

[plain] view plaincopy

$ docker ps

CONTAINER ID IMAGECOMMAND CREATED STATUS PORTSNAMES

d8e703d7e303 solidleon/ssh:latest /usr/sbin/sshd -D cranky_pare

$ docker inspect -f '{{.Id}}' cranky_pare

or

$ docker inspect -f '{{.Id}}' d8e703d7e303

d8e703d7e3039a6df6d01bd7fb58d1882e592a85059eb16c4b83cf91847f88e5

$ sudo cp file.txt /var/lib/docker/aufs/mnt/**d8e703d7e3039a6df6d01bd7fb58d1882e592a85059eb16c4b83cf91847f88e5

3.用输入输出符

[plain] view plaincopy

docker run -i ubuntu /bin/bash -c 'cat >/path/to/container/file' </path/to/host/file/

或者

[plain] view plaincopy

docker exec -it <container_id>bash -c '昌蚂滚cat >/path/to/container/file' </path/to/host/file/

从Docker容器内拷贝文件到主机上

docker cp :/file/path/within/container /host/path/target

从主机上拷贝文件到容器内

参考自:

1.用-v挂载主机数据卷到容器内

docker run -v /path/to/hostdir:/mnt $container

在容器内拷贝

cp /mnt/sourcefile /弊巧path/to/destfile

2.直接在主机上拷贝到容器物理存储系统

A. 获取容器名称或者id :

$ docker ps

B. 获取整个容器的id

$ docker inspect -f '{{.Id}}' 步骤A获取的名称或者id

C. 在主机上拷贝文册桐件:

$ sudo cp path-file-host /var/lib/docker/aufs/mnt/FULL_CONTAINER_ID/PATH-NEW-FILE

或者

$ sudo cp path-file-host /var/lib/docker/devicemapper/mnt/123abc<>/rootfs/root

例子:

$ docker ps

CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES

d8e703d7e303 solidleon/ssh:latest /usr/sbin/sshd -D cranky_pare

$ docker inspect -f '{{.Id}}' cranky_pare

or

$ docker inspect -f '{{.Id}}' d8e703d7e303

d8e703d7e3039a6df6d01bd7fb58d1882e592a85059eb16c4b83cf91847f88e5

$ sudo cp file.txt /var/lib/docker/aufs/mnt/**d8e703d7e3039a6df6d01bd7fb58d1882e592a85059eb16c4b83cf91847f88e5

3.用输入输出符

docker run -i Ubuntu /bin/bash -c 'cat >/path/to/container/file' </path/to/host/file/

或州卜坦者

docker exec -it bash -c 'cat >/path/to/container/file' </path/to/host/file/

docker跟宿主机交互的是通过原生网络实现的。

当Docker进程启动之后,它会配置一个虚拟的源没指网桥叫docker0在宿主机上。这个接口允许Docker去分配虚拟的子网给即将启动的容器们。这个网桥在容器内的网察肢络和宿主机网络之间将作为接口雹配的主节点。

Docker容器启动后,将创建一个新的虚拟接口并分配一个网桥子网内的IP地址。这个IP地址嵌在容器内网络中,用于提供容器网络到宿主机docker0网桥上的一个通道。Docker自动配置iptables规则来放行并配置NAT,连通宿主机上的docker0,就可以访问宿主机的mysql数据文件了。


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/tougao/12256977.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-24
下一篇 2023-05-24

发表评论

登录后才能评论

评论列表(0条)

保存