Docker数据管理、网络通信、资源控制、docker swarm集群配置与使用

本文详细介绍了Docker的数据管理,包括数据卷和数据卷容器的使用。接着讲解了Docker的网络通信,如端口映射和容器互联。此外,还探讨了Docker Swarm的配置和使用,以及如何在Swarm集群上部署应用。最后,文章涉及了Docker的资源控制,如CPU和内存的限制策略。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

Doker数据管理

容器的数据管理操作可以方便查看容器内产生的数据或者将多个容器中的数据实现共享。管理Docker容器中数据主要有两种方式:数据卷(Data Volumes)和数据卷容器(Data Volumes Containers)。


一、数据卷(学习课本上是自行创建my-vol,这里实际运用一下,具体大家可以网上搜一下教程)

数据卷是一个供容器使用的特殊目录,位于容器中,可将宿主机的目录挂载到数据卷上,实现数据在宿主机与容器之间的迁移。

1.下载镜像centos

docker pull centos

2.创建数据卷

#使用centos镜像创建一个名为web1的容器,并且创建两个数据卷分别挂载到/data1与/data2目录上,这里的目录文件自行创建

docker run -d -v /data1 -v /data2 --name web1 -it centos /bin/bash

Docker数据管理、网络通信以及资源控制,下面是我觉得实验中我不知道的参数,也比较常用

        -i : 让容器对的输入保持打开
        -t : 让Docker分配一个伪终端
        -d : 让docker以守护形式在后台运行

3.进入容器查看/data1与/data2目录

docker exec -it web1 /bin/bash

ls -l

 


4.挂载主机目录作为数据卷

#使用centos镜像创建一个名为web2的容器,将宿主机的/var/www目录挂载到容器的/data1目录

docker run -d -v /var/www:/data1 --name web2 -it centos /bin/bash

注意:宿主机本地目录的路径必须使用绝对路径,如果路径不存在,Docker会自动创建相应的路径。

5.在宿主机的/var/www目录下创建一个文件file
 

cd /var/www

touch file

ls


6.进入运行着的容器中,到相应挂载目录/data1目录下查看

docker exec -it web2 /bin/bash

cd /data1

ls


实现了从宿主机到容器的数据迁移。


二、数据卷容器

数据卷容器就是一个普通容器,专门提供数据卷给其他容器挂载使用。实现在容器之间共享一些数据。
1.创建一个容器作为数据卷容器

使用前面创建好的数据卷容器web1
2.使用--volumes-from来挂载web1容器中的数据卷到新的容器,新的容器名为db1

docker run -it --volumes-from web1 --name db1 centos /bin/bash

ls


3.在db1容器的数据卷/data2目录下创建一个文件file

cd /data2

touch file

ls


4.在web1容器中的/data2目录中查看创建的file文件

docker exec -it web1 /bin/bash

cd /data2

ls


这样就可以通过数据卷容器实现容器之间的数据共享。


Docker网络通信

Docker提供了映射端口到宿主机和容器互联机制来为容器提供网络服务。


一、端口映射

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

根据书本所写以及我看的网上的教程材料可以知道,实现端口映射可以用两种方式

#方法一:
命令格式: docker run -d -P 镜像名称
其中-P(大写)选项实现随机映射

#方法二:
命令格式: docker run -d -p 宿主机的端口号:容器内的端口号 镜像名称
其中-p(小写)选项指定要映射的端口


1.端口随机映射

 docker run -d -P httpd:centos   #随机映射

使用docker ps -a命令查看端口的映射

2.指定端口映射

 

docker run -d -p 49280:80 httpd:centos #指定端口映射

使用docker ps -a命令查看端口的映射

二、容器互联

容器互联是通过容器的名称在容器键建立一条专门的网络通信隧道从而实现容器的互联。简单点说,就是在源容器和接收容器间建立一条隧道,接收容器可以看到源容器指定的信息。

格式为--link name:alias
其中name是要连接的容器名称,alias是这个连接的别名

1.创建源容器

使用docker命令建立容器A,使用--name指定容器名称为test1.

docker run -itd -P --nam
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值