Docker 数据管理和网络通信

Docker 数据管理

在Docker中,为了方便查看容器内产生的数据或者将多个容器中的数据实现共享,就涉及到容器的数据管理操作。
管理Docker容器中数据只要有两种方式:数据卷(Data Volumes)和数据卷容器(Data Volumes Containers)

数据卷

数据卷是一个供容器使用的特殊目录,位于容器中,可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移。

1.创建数据卷

在docker run命令中使用-v选项可以在容器内创建数据卷。多次使用-v选项可以创建多个数据卷。使用--name选项可以给容器创建一个有好的自定义名称。

例子:

docker pull centos #下载镜像
#宿主机目录/var/www 挂载容器中的/data1
docker run -v /var/www:/data1 --name web1 -it centos /bin/bash
[[email protected] /]# cd /data1/
[[email protected] data1]# touch test
[[email protected] data1]# exit
#返回宿主机进行查看
[[email protected] ~]# ls /var/www/

2.数据卷容器

如果需要在容器之间共享一些数据,最简单的方法就是使用数据卷容器。数据卷容器就是一个普通的容器,专门提供数据卷给其他容器挂载使用。
使用方法:首先,需要创建一个容器做为数据卷容器。之后在其他容器创建时用 --volumes-from 挂载数据卷容器中的数据使用。

例子:

#创建2个数据卷/data1,/data2, 数据卷容器web200
docker run --name web200 -v /data1 -v /data2 -it centos /bin/bash
exit #退出容器
#新容器db1挂载到数据卷容器web200
docker run -it --volumes-from web200 --name db1 centos /bin/bash
mkdir /data1/test2 #在容器db1里面建立目录test2
exit #退出容器
docker start web200 #启动数据卷容器
docker exec -it web200 /bin/bash #进入数据卷容器
[[email protected] /]# ls /data1/ #在数据卷容器web200可以看到新容器db1新建目录
test2

端口映射

Docker提供端口映射机制来将容器内的服务提供给外部网络访问,实质上就是将宿主机的端口映射到容器中,使得外部网络访问宿主机的端口便可以访问容器内的服务。

例子:

docker pull nginx #下载镜像
docker run -d -P nginx #运行镜像 -P(大写)随机映射端口

网页验证:

或者:

docker run -d -p 81:80 nginx #指定映射端口81
docker ps -a

网页验证:

容器间互联

1.创建源容器

docker run -P --name web1 -itd nginx /bin/bash #创建并运行容器取名web1,端口号自动映射

2.创建接受容器

docker run -P --name web2 --link web1:web1 -itd nginx /bin/bash #创建并运行容器取名web2,链接到web1和其通信

3.测试容器互联

进web2 容器 ping 源容器
docker exec -it 9ee4fdb533ac /bin/bash
ping web1

如果出现下面问题:

可以这样解决:

apt-get update
apt install iputils-ping

再尝试ping web1:

原文地址:https://blog.51cto.com/13760351/2471451

时间: 2024-08-02 09:04:08

Docker 数据管理和网络通信的相关文章

Docker数据管理及网络通信

Docker数据管理及网络通信 在Docker中,为了方便查看容器中产生的数据或者将多个容器中的数据共享,就涉及到容器的数据管理操作.管理Docker容器中的数据主要有两种方式:数据卷(Date Volumes)和数据卷容器(Data Volumes Containers). 数据卷 数据卷是一个供容器使用的特殊目录,位于容器中,可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立刻可见,并且更新数据不会影响镜像,从而实现数据在宿主机和容器之间迁移.数据卷的使用类似于Linux下对目录进行的mo

Docker数据管理、网络通信以及资源控制

Docker的安装及镜像.容器的基本操作详见博客http://blog.51cto.com/11134648/2160257下面介绍Docker数据管理.网络通信以及资源控制的方法,详细如下: Doker数据管理 容器的数据管理操作可以方便查看容器内产生的数据或者将多个容器中的数据实现共享.管理Docker容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(Data Volumes Containers). 一.数据卷 数据卷是一个供容器使用的特殊目录,位于容器中,可将宿主

Docker数据管理与网络通信

Docker镜像的创建方法 Docker镜像除了是Docker的核心技术之外也是应用发布的标准格式.一个完整的Docker镜像可以支撑一个Docker容器的运行,在Docker的整个使用过程中,进入一个已经定型的容器之后,就可以在容器中进行操作,最常见的就是在容器中安装应用服务,如果要把已经 安装的服务进行迁移,就需要把环境以及搭建的服务生成新的镜像. 创建镜像的方法有三种: 基于已有镜像创建 基于本地模板创建 基于Docherfile创建 基于已有镜像创建 使用docker commit命令,

Docker数据管理与网络通信之镜像的创建方法

Docker镜像的创建方法 Docker镜像除了是Docker的核心技术之外,也是应用发布的标准格式. 一个完整的Docker镜像可以支撑一个Docker容器的运行,在Doker的整个使用过程中,进入一个已经定型的容器之后,就可以在容器中进行操作,最常见的操作就是在容器中安装应用服务,如果要把已经安装的服务进行迁移,就需要把环境以及搭建的服务生成新的镜像. 创建镜像的方法有三种,分别为基于已有镜像创建.基于本地模板创建以及基于Dockerfile创建. 基于已有镜像创建 基于已有镜像创建主要使用

Docker数据管理(四)

Docker数据管理 Docker数据分为两种: 数据卷 -v /data -v src:dst 数据卷容器 --volumes-from 数据卷 案例1:我们创建一个容器,起名叫nginx-volume-demo1挂载到容器中的/data目录下 [[email protected] ~]# docker run -d --name nginx-volume-demo1 -v /data nginx 96892a7bb67e9c687f29d07ea674ca527ab09dee6b0ec121

Docker 数据管理

Docker 数据管理 数据卷 数据卷是一个可供一个或多个容器使用的特殊目录,它绕过 UFS,可以提供很多有用的特性: 1.  数据卷可以在容器之间共享和重用 2.  对数据卷的修改会立马生效 3.  对数据卷的更新,不会影响镜像 4.  卷会一直存在,直到没有容器使用 挂载本地目录到容器 创建一个数据卷 在用 docker run 命令的时候,使用 -v 标记来创建一个数据卷并挂载到容器里.在一次 run 中多次使用可以挂载多个数据卷. #sudo docker run -it -v ~/da

(九)Docker数据管理

Docker数据管理,即Docker内部以及容器之间管理数据,主要有两种方式:数据卷和挂载. 1. 数据卷(Volume) volume,可供一个或多个容器使用的特殊目录. 数据卷可在容器之间共享和重用: 对数据卷的修改会立马生效: 对数据卷的更新,不会影响镜像: 数据卷默认会一直存在,即使容器被删除:(可通过 docker volume prune命令删除无效的volume) 数据卷的使用,类似于 2. 挂载主机目录(Bind mounts) 原文地址:https://www.cnblogs.

Docker的数据管理及网络通信问题

博文大纲: 一.docker的数据管理1.数据卷2.数据卷容器 二.docker网络通信1.端口映射2.容器互联 一.docker的数据管理 在docker中,为了方便查看容器内产生的数据或者将多个容器之间的数据实现共享,会涉及到容器的数据管理操作,管理docker容器中的数据主要有两种方式:数据卷和数据卷容器. 1.数据卷 数据卷是一个供容器使用的特殊目录,位于容器中,可将宿主机的目录挂载到数据卷上,对数据卷的修改操作立即可见,并且更新数据不会影响镜像,从而实现数据在宿主机与容器之间的迁移,数

3 docker数据管理

数据管理 关于容器中的数据 1.容器关闭,然后再启动容器,数据是存在的. 2.创建容器,然后把容器删除,数据随着容器的删除也被删除 3.如何删除容器不删除数据,在创建容器的时候可以采用以下做法 1 在创建容器时,挂载宿主机目录到容器 # docker run -itd -v /data/:/database centos 0ccaba523bc559b311b2b093b3b8617a9ddb2b4ac55124dd458dd991a240ae55 # docker exec -it 0cc /