centos7下安装docker(12.5容器在单个host上的网络总结)
单个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上的网络总结)的更多相关文章
- centos7下安装docker(19容器架构)
What,Why,How What:什么是容器? 说起容器大家想到的是什么? 集装箱(container),虚拟机,docker,k8s 1. 没毛病,因为容器与集装箱的英文都可以翻译成co ...
- centos7下安装docker(11容器操作总结)
这段时间主要是学习了对容器的操作,包括:容器的状态:start,stop,restart,rename,pause,unpause,rm,attach,exec,kill,logs:还学习了对容器的资 ...
- centos7下安装docker(10容器底层--cgroup和namespace)
cgroup和namespace是实现容器底层的重要技术 cgroup:实现资源限制 namespace:实现资源隔离 1.cgroup:control group Linux操作系统通过cgroup ...
- centos7下安装docker(9容器对资源的使用限制-内存)
一个docker Host上面会运行若干容器,每个容器都需要CPU,内存和IO资源.容器提供了控制分配多少CPU,内存给每个容器的机制,避免摸个容器因占用太多资源而影响其他 ...
- CentOS7下安装docker(Docker系列1)
CentOS7下安装docker 系统要求 为了安装docker,需要准备 64-bit的CentOS 7 删除非官方的Docker包 yum的仓库中有一个很旧的Docker包, 现在Docker官方 ...
- docker(一) Centos7下安装docker
docker(一) Centos7下安装dockerdocker(二) windows10下安装dockerdocker(三) 镜像和容器常用命令 docker(四) 使用Dockerfile构建镜像 ...
- centos7下安装docker与镜像加速
1.背景 centos7下安装docker 2.安装 第一步:检查是否为centos7版本 第二步:依赖环境安装 执行如下两个命令: yum -y install gcc yum -y install ...
- centos7下安装docker(15.1跨主机网络)
之前学习了单个host上的网络,我们知道单个host上的网络有:none,host,bridge和joined,他们解决了单个host上面的容器通信的问题:接下来我们讨论跨主机间容器通信的方案 跨主机 ...
- centos7下安装docker(15.5容器跨主机网络--flanneld)
flannel是由CoreOS研究的一种覆盖网络(overlay network)网络工具,目的是帮助每一个host主机有一个完整的子网: 功能是:让集群中不同节点的主机创建的容器都有一个唯一的虚拟I ...
随机推荐
- maven教程5(聚合工程)
所谓聚合项目,实际上就是对项目分模块,互联网项目一般来说按照业务分(订单模块.VIP模块.支付模块.CMS模块...),传统的软件项目,大多采用分层的方式(Dao.Serivce.Controller ...
- SSM-动态SQL
SSM-动态SQL ssm框架 Mybatis 动态SQL主要是解决同一类SQL语句匹配不同的问题,举个栗子: 加入我要执行一个查询语句,但是是一个不确定的查询语句,可能会根据ID去查,如果ID没有 ...
- 前后端分离demo 旅馆管理系统
模型设计 旅馆管理系统,主要涉及到登记入住,退房以及客房和客人信息管理:经过分析抽像出涉及到的实体以及各实体之间的关系: 可以看出整个业务以客房为中心,入住,退房,定价,收费都是以客房为基本单 ...
- RMQ问题(Sparse-Table算法)
范围最值问题(Range Minimum/maximum Query,RMQ).给出一个哪个元素的数组A1,A2,...An,要求设计一个数据结构,支持查询操作:计算min(AL,AL+1,...,A ...
- js------科学计数法转换为正常小数
// toD.js文件export default (val) => { const e = String(val) let rex = /^([0-9])\.?([0-9]*)e-([0-9] ...
- 百度api查询多个地址的经纬度的问题
在使用百度api查询多个地址的经纬度的时候,由于百度api提供的经纬度查询方法是回调函数,并且后续操作必须等经纬度获取完成才能进行,问题就存在于怎么判断所有地点是否都回调完成了,问了之前的一个前端大佬 ...
- Java学习笔记之——循环语句
一.for循环 语法: for(变量初始化:条件判断:更新循环变量){ 循环体: } 案例: 二.while循环 语法: while(条件){ 循环体: } 如果条件为true,执行循环体,false ...
- 在CentOS下的docker容器中部署spring boot应用的两种方式
我们通常在 windows 环境下开发 Java,而通常是部署在Linux的服务器中,而CentOS通常是大多数企业的首选,基于Docker的虚拟化容器技术,多数Java应用选择这种方式部署服务.本文 ...
- design mode(php)
前段时间看了下设计模式 参考,以及head first设计模式,简要如下 ## OO原则 * 封装变化* 多用组合,少用继承* 针对接口编程,不针对实现编程* 为交互对象之间的松耦合设计而努力* 开闭 ...
- ngx-echarts响应式图表
一.代码 html代码 <!-- html --> <nz-card style="background-color: #0e0b2a;border: 0px;color: ...