前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Docker 网络配置

Docker 网络配置

作者头像
为为为什么
发布2024-08-01 09:21:08
1720
发布2024-08-01 09:21:08
举报
文章被收录于专栏:又见苍岚

Docker 在使用过程中可以配置网络工作模式,来控制容器之间、容器与主机之间的通信方式。本文详细介绍了Docker中的网络功能,包括网络模式(桥接、主机、容器、none和自定义网络)的应用,容器间的通信解决方案,以及如何创建和管理网络以实现服务名直接通信。

概述

需要解决的问题

(1)容器间、容器与主机间的互联和通信以及端口映射

(2)容器IP变动时候,可以通过服务名直接网络通信而不受到影响

基本用法

123456789101112131415161718192021

连接容器到网络docker network connect 网络名 # 创建网络(使用统一网络的容器,肯定可以ping通)docker network create 网络名 # 断开网络docker network disconnect 网络名# 查看网络具体信息docker network inspect # 查看所有网络列表docker network ls # 删除无用网络docker network prune # 删除指定的网络docker network rm

五种网络模式

网络模式

命令指定方式

描述

理解

bridge

–network bridge

为每一个容器分配、设置 ip ,并将容器连接到 docker0 虚拟网桥上,虚拟网桥,默认为该网络模式

一人一个

host

–network host

容器不会创建自己的网卡,配置 ip 等,而是使用宿主机的 ip 和端口

多人一个

container

–network 容器名称或id

新创建的容器不会创建自己的网卡和配置自己的ip,而是和一个指定的容器共享ip、端口范围等

自己没有,用别人的

none

–network none

容器有独立的Network namespace,但并没有对其进行任何网络设置,如网桥,ip等

有,但是空的

桥接模式—— bridge

为每一个容器分配、设置IP等,并将容器连接到docker0的虚拟网桥。若没有特别申明,则为默认自带一个IP以及网络设置。

  • Docker使用Linux桥接的方式,在宿主机虚拟一个Docker容器网桥(docker0)。 Docker每启动一个容器时会根据Docker网桥的网段分配给容器一个ip地址。 同时Docker网桥是每个容器的默认网关。 同一宿主机内的容器都接入同一个网桥,这样容器之间就能够通过容器的Container-IP直接通信。
  • docker run创建容器的时,未指定network的容器默认的网络模式就是bridge,使用的就是docker0。 在宿主机ifconfig,就可以看到docker0和自己创建的network:
代码语言:txt
复制
- eth0,eth1……代表网卡一,网卡二……
- lo代表127.0.0.1(localhost)
- inet addr表示网卡的ip地址网桥docker0会创建一对对等虚拟设备接口:一个叫veth,另一个叫eth0,成对匹配。
整个宿主机的网桥模式都是docker0,类似一个交换机有一堆接口,每个接口叫veth,
在本地主机和容器内分别创建一个虚拟接口,并让他们彼此联通(这样一对接口叫veth pair);
每个容器实例内部也有一块网卡,每个接口叫eth0;
docker0上面的每个veth匹配某个容器实例内部的eth0,两两配对。
主机模式—— host

容器不会虚拟出自己的网卡、IP等,而是使用宿主机的IP和端口。

注意:在创建的时候,将再在指定 -p 8083:8080, 无意义,运行时候会警告,但是不报错。因为该容器和主机ip和端口同步。

容器模式—— container

新创建的容器不会创建自己的网卡,没有自己的IP,也不会进行相应的配置。而是和一个指定的容器共享IP端口范围等。

注意:当192.168.20.2容器停掉后,192.168.20.3的网络也会同时停掉!

1

--network container:共享的容器名/ID

none模式—— none

容器有自己独立的Network namespace,但是没有进行任何的相关配置。即禁用网络功能,只有lo标识(就是127.0.0.1表示本地回环)

  • 在none模式下,并不为Docker容器进行任何网络配置。 也就是说,这个Docker容器没有网卡、IP、路由等信息,只有一个lo。 需要我们自己为Docker容器添加网卡、配置IP等。
自定义网络

为使得众多的容器,进行分门别类,方便管理的情况下,而且通过服务名来ping通,所以采用自定义网络进行管理!

123456

#创建新的网络,默认为bridge模式docker network create new_net# 新创建两个容器tomcat81和tomcat82,并调用新建的自定义网络docker run -d -p 8081:8080 --network new_net --name tomcat81 billygoo/tomcat8-jdk8docker run -d -p 8082:8080 --network new_net --name tomcat82 billygoo/tomcat8-jdk8

总结,自定义网络本身就维护好了主机名和ip的对应关系( ip和域名都能通)

IPC 配置

Docker的IPC(Inter-Process Communication,进程间通信)配置主要用于控制容器间是否可以进行进程间通信。在Docker中,可以通过设置--ipc参数来配置IPC命名空间。

以下是一些常用的IPC设置:

  • none:容器拥有自己的IPC命名空间,不与其他容器共享。
  • private:容器拥有自己的IPC命名空间,但是可以与其他容器共享进程、消息队列和信号量。
  • host:容器使用宿主机的IPC命名空间。
  • container:<name|id>:容器与指定的容器共享IPC命名空间。

例如,如果你想要两个容器使用相同的IPC命名空间,可以这样设置:

12

docker run --name container1 --ipc=host myimage1docker run --name container2 --ipc=host myimage2

或者,如果你想要让container2container1共享IPC命名空间:

12

docker run --name container1 --ipc=private myimage1docker run --name container2 --ipc=container:container1 myimage2

在Docker Compose中,可以在docker-compose.yml文件中设置IPC模式:

12345678

version: '3'services: service1: image: myimage1 ipc: host service2: image: myimage2 ipc: "container:service1"

请注意,在使用IPC设置时,你需要考虑到安全问题,因为容器间的IPC会提供一种进程间通信的方式,可能被恶意利用。

参考资料

文章链接: https://cloud.tencent.com/developer/article/2441246

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2024-7-31,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 概述
  • 基本用法
  • 五种网络模式
    • 桥接模式—— bridge
      • 主机模式—— host
        • 容器模式—— container
          • none模式—— none
            • 自定义网络
            • IPC 配置
            • 参考资料
            相关产品与服务
            容器服务
            腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档