怎样将Docker容器中的文件导入到主机

怎样将Docker容器中的文件导入到主机,第1张

从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数据文件了。

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/


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

原文地址: https://outofmemory.cn/tougao/11921325.html

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

发表评论

登录后才能评论

评论列表(0条)

保存