docker实现容器与宿主机互传文件

本文介绍了如何在Docker环境下实现容器与宿主机之间的文件互传。通过-v参数挂载目录进行文件复制,或者利用docker inspect获取容器ID,通过/var/lib/docker/aufs/mnt/通道直接进行拷贝操作。

Docker实践2中使用-v参数将主机与容器中相关目录联系在一起(挂载),所以我们可以用这个通道将想要互相拷贝的数据放入其中,这样就可以用cp命令来复制文件了。

除了这个办法,我们还可以分别用不同的命令来拷贝数据。

从容器中像主机拷贝数据

Docker提供了cp命令,用法如下:
# docker ps
CONTAINER ID        IMAGE                     COMMAND                CREATED             STATUS              PORTS                         NAMES        
a77a72ac178c        tutum/apache-php:latest   "/run.sh"              21 hours ago        Up 21 hours         0.0.0.0:8080->80/tcp          phpapache_phpapache_1
# docker-enter a77a72ac178c
root@a77a72ac178c:~# ls /var/www/html
index.php  logo.png
root@a77a72ac178c:~# exit
logout

# docker cp a77a72ac178c:/var/www/html /var/www/
# ls /var/www/
app  download  index.html
# ls /var/www/app/
index.php  logo.png

从主机向容器中拷贝数据

这里要使用一个docker提供的神奇通道来完成主机向容器的数据传输。 
首先要用docker inspect方法获得容器的完整id,

 inspect   Return low-level information on a container

然后用/var/lib/docker/aufs/mnt/通道来完成拷贝。 
举例如下:

# docker inspect -f '{{.Id}}' a77a72ac178c
a77a72ac178c1e35708d2af446197c10239b0b1bd8932104578e334b83eb93a2
# cp docker/docker-start.sh /var/lib/docker/aufs/mnt/a77a72ac178c1e35708d2af446197c10239b0b1bd8932104578e334b83eb93a2/root/
# docker-enter a77a72ac178c
# pwd
/root
# ls
docker-start.sh
### Docker 容器宿主机的数据传输和通信 #### 网络通信方式 容器内的网络地址和宿主机网络地址具有相同的标志位。这意味着在创建容器时,会成对地创建虚拟以太网接口(veth pair),并且这些接口通过宿主机上的 `docker0` 网桥进行通信[^2]。 对于同一台宿主机上运行的不同容器而言,可以通过多种方式进行相互通信: - **直接 IP 访问**: 可以获取各个容器内部分配到的具体 IPv4 地址并利用该地址实现互相间的访问。 - **端口映射 (Port Mapping)**: 使用 `-p` 或者 `--publish` 参数指定外部可访问的服务端口号,在启动容器的时候设置好相应的参数即可让外界能够经由宿主机来接触目标服务。 - **自定义网络模式**: 创建用户自定义的 bridge、overlay 类型或者其他形式的网络拓扑结构以便更灵活地管理多容器环境下的连通性和隔离度。 当涉及到不同宿主机之间的 Docker 容器通讯时,则通常依赖于底层物理网络设施的支持以及可能涉及的一些高级特性比如 VXLAN 技术或是其他第三方工具和服务的帮助来进行跨节点互联操作[^4]。 #### 文件共享机制 为了使多个容器可以共同读写某些特定路径下存储的信息资源,Docker 提供了几种不同的卷挂载选项用于支持文件系统的交互: - **Bind Mounts**: 将宿主机某个现有目录作为数据源绑定至新启动起来的一个或数个容器内相应位置处; ```bash docker run -d --name my_container -v /path/on/host:/mnt/data alpine sh -c "while true; do sleep 3600; done" ``` - **Volumes**: 利用 Docker 自身维护的一套独立持久化层来保存重要资料,并允许任意数量的工作单元按需接入此区域完成任务协作; ```bash docker volume create my_volume docker run -d --name another_container -v my_volume:/data busybox sh -c "echo 'hello world' > /data/message.txt" ``` 需要注意的是,尽管两个容器可能会被配置为共享同一个网络命名空间从而简化彼此间消息传递流程,但这并不意味着它们也会自动同步任何磁盘上的变动情况——除非特别指定了上述提到的一种合适的方式去处理这个问题[^3]。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值