单个host上的容器的网络:通过本章的学习,我们知道docker默认有三种网络,可以通过docker network ls查看;

none:封闭的网络,通过--network=none来指定;

host:将host主机上面的网络完全映射到容器中;

bridge:桥接网络,默认情况下容器使用的是bridge,并将容器网络桥接到docker0上;可以通过brctl show查看桥接情况

我们可以创建user-defined网络,user-defined也分为三种:bridge,overlay,macvlan,本节重点讨论的是bridge,其他两个主要用来实现跨主机的网络;

通过docker network create --driver bridge <网络名>来创建bridge网络,通过docker network inspect查看bridge的subnet以及gateway;

我们新建bridge网络的时候可以通过--subnet和--gateway来指定bridge的网段和网关;

运行容器的时候我们通过--network=<新建的网络名>指定容器使用的网段,通过--ip指定容器的ip;

通过docker network rm<网络ID>来删除不用的网络,前提是这个网络没有被使用。

我们还学习了容器与容器之间的通信:证明了在同一个网络下的容器之间可以互相通信;在不同网络的容器可以设置iptables来实现,也可以通过docker network connect  <网络名> <容器名> 来给容器增加一个不同网段的新网卡来实现不同网段的容器之间的通信;

容器间的通信方式有三种:IP通信,DNS通信,joined方式通信

最后学习了容器如何与外部进行通信:通过NAT的方式来实现容器访问外网:容器发送请求先到桥接网卡(docker0),桥接网卡发现是访问外网的通过NAT进行网络地址转换,将容器的地址转换成host的地址,通过host的地址访问外部;

通过端口映射的方式实现了外部访问容器:首先启动容器的时候要通过-p设置容器映射的端口,每映射一个端口,host都会启动一个docker-proxy的进程;当外部有请求过来时,先访问host对应的端口,然后通过docker-proxy将请求转发到容器对应的端口,容器在将结果返回。

本节的命令总结:

brctl show:桥接情况

docker  network ls:查看docker网络

docker network create --driver bridge --subnet --gateway docker1:创建一个docker1的bridge网络

--driver bridge:驱动类型为bridge ;--subnet指定网段;--gateway指定网关

docker run -d --network=none/host/docker1 --ip 192.168.2.2 busybox :运行一个容器指定他使用的网络和ip

--network=none/host/docker1  指定使用的网络   --ip指定容器的ip

docker network inspect <网络ID>查看bridge网络的信息

docker network connect  <网络名> --ip <容器名> 给容器增加一块网卡

docker network rm <网络ID>删除网络

centos7下安装docker(12.5容器在单个host上的网络总结)的更多相关文章

  1. centos7下安装docker(19容器架构)

    What,Why,How What:什么是容器? 说起容器大家想到的是什么?      集装箱(container),虚拟机,docker,k8s 1. 没毛病,因为容器与集装箱的英文都可以翻译成co ...

  2. centos7下安装docker(11容器操作总结)

    这段时间主要是学习了对容器的操作,包括:容器的状态:start,stop,restart,rename,pause,unpause,rm,attach,exec,kill,logs:还学习了对容器的资 ...

  3. centos7下安装docker(10容器底层--cgroup和namespace)

    cgroup和namespace是实现容器底层的重要技术 cgroup:实现资源限制 namespace:实现资源隔离 1.cgroup:control group Linux操作系统通过cgroup ...

  4. centos7下安装docker(9容器对资源的使用限制-内存)

                  一个docker Host上面会运行若干容器,每个容器都需要CPU,内存和IO资源.容器提供了控制分配多少CPU,内存给每个容器的机制,避免摸个容器因占用太多资源而影响其他 ...

  5. CentOS7下安装docker(Docker系列1)

    CentOS7下安装docker 系统要求 为了安装docker,需要准备 64-bit的CentOS 7 删除非官方的Docker包 yum的仓库中有一个很旧的Docker包, 现在Docker官方 ...

  6. docker(一) Centos7下安装docker

    docker(一) Centos7下安装dockerdocker(二) windows10下安装dockerdocker(三) 镜像和容器常用命令 docker(四) 使用Dockerfile构建镜像 ...

  7. centos7下安装docker与镜像加速

    1.背景 centos7下安装docker 2.安装 第一步:检查是否为centos7版本 第二步:依赖环境安装 执行如下两个命令: yum -y install gcc yum -y install ...

  8. centos7下安装docker(15.1跨主机网络)

    之前学习了单个host上的网络,我们知道单个host上的网络有:none,host,bridge和joined,他们解决了单个host上面的容器通信的问题:接下来我们讨论跨主机间容器通信的方案 跨主机 ...

  9. centos7下安装docker(15.5容器跨主机网络--flanneld)

    flannel是由CoreOS研究的一种覆盖网络(overlay network)网络工具,目的是帮助每一个host主机有一个完整的子网: 功能是:让集群中不同节点的主机创建的容器都有一个唯一的虚拟I ...

随机推荐

  1. C语言之链表的使用

    C语言链表初学者都说很难,今天就来为大家讲讲链表 讲链表之前不得不介绍一下结构体,在链表学习之前大家都应该已经学了结构体,都知道结构体里面能有许多变量,每个变量可以当做这个结构体的属性,例如: str ...

  2. SQLServer删除登录记录用户名和密码

    介绍: 作为一名开发人员都会知道我们做的项目都要用到数据库,数据库都需要账号和密码,然而问题来了,做的东西多了那些没用的账号和密码还在哪里纠缠着我们.所有我们不能忍了删除掉他. 网上很多都是2008的 ...

  3. 基于Zookeeper的分布式锁

    实现分布式锁目前有三种流行方案,分别为基于数据库.Redis.Zookeeper的方案,其中前两种方案网络上有很多资料可以参考,本文不做展开.我们来看下使用Zookeeper如何实现分布式锁. 什么是 ...

  4. SQL Server 连接(内连接,外连接,完全连接,交叉连接,联合)

    1.连接 有时候需要将连个表的数据合并成一个结果集来显示.为了解决这个问题,就需要用到JOIN连接. 2.内部连接 内部连接根据一个或几个共同的字段将记录匹配到一起.内部连接仅仅返回那些存在字段匹配的 ...

  5. spark_wordcount

    spark是基于scala写的,虽然spark有java API,或者python API,但是scala算是正统吧. 而且scala的语法书写起来十分的爽,不想java那样笨重,python不太了解 ...

  6. deepin使用笔记-解决蓝牙设备开机自动开启的问题

    我的邮箱地址:zytrenren@163.com欢迎大家交流学习纠错! 1.安装蓝牙驱动管理 #apt-get install blueman 2.打开蓝牙驱动管理,关闭设备 3.关闭蓝牙开机启动服务 ...

  7. sql server: quering roles, schemas, users,logins

    --https://docs.microsoft.com/en-us/sql/relational-databases/security/authentication-access/managing- ...

  8. flex 布局下,css 设置文本不换行时,省略号不显示的解决办法

    大致是有一个 main 容器是 flex 布局,左边一个 logo 固定宽高,右边 content 动态宽度. <div class="main"> <img a ...

  9. JMeter 查看结果树监听器响应数据中文显示乱码解决方法

    查看结果树监听器响应数据中文显示乱码解决方法 by:授客 QQ:1033553122   问题描述 使用监听器-查看结果树(View Results Tree Listener)过程中发现,响应数据面 ...

  10. loadrunner 运行脚本-Run-time Settings-Browser Enmulation设置详解

    运行脚本-Run-time Settings-Browser Enmulation设置详解 by:授客 QQ:1033553122 浏览器模拟 所有Internet Vuser Header包含一个标 ...