安装docker以后自动添加三种网络方式

  bridge: 表示桥接网络 (在本地自动创建一个软交换机)

  host: 表示让容器使用宿主机的网络名称空间

  none: 表示没有网络 不能执行网络通信。

    

创建容器的同时会创建一对网卡 一半在物理机上(自动关联bridge)一半在容器里面

可以通过以下命名查看关联关系

  yum -y install bridge-utils

  brctl show

  ip link show

容器的网络名称空间 UTS IPC是可以被共享的

添加网络名称空间

  前奏

    rpm -q iproute

    ip netns help

  添加:

    ip netns add r1

  在网路名称空间中执行命令:

    ip netns exec r1 ifconfig -a  (此时网络名称空间是没有被激活的,需要添加虚拟网卡对)

  手动添加虚拟网卡对:

    ip link add name veth1.1 type veth peer name veth1.2

      name 指定第一半的名字

      type 类型

      peer 指定另一半的相关信息

  把虚拟网卡移动的名称空间里面:

    ip link set dev weth1.2 netns r1

  给名称空间里面的虚拟网卡改名:

    ip netns exec r1 ip link set dev veth1.2 name eth0

  激活宿主机上的虚拟网卡:

    ifconfig veth1.1 10.1.0.1/24 up

  激活名称空间里面的网卡:

    ip netns exec r1 ifconfig eth0 10.1.0.2/24 up

  查看名称空间里面的虚拟挖网卡ip:

    ip netns exec r1 ifconfig

使用封闭式容器 (none)

  docker run --name t3 -it --network none --rm busybox:latest

指定bridge网络(默认就是bridge)可以和当前主机的其它容器通信

  docker run --name t3 -it --network bridge --rm busybox:latest

  创建容器的时候指定主机名:

    docker run --name t3 -it --network bridge -h t3.com --rm busybox:latest

  暴露端口给其他主机访问:

    docker run --name t3 -it -p 80 --rm wang/httpd:v0.2

      -p 随机生成物理端口

      -P 不用指定端口 会自己暴露

      

  查看容器端口映射到具体哪个物理地址

    docker port 容器名称

  指定容器端口绑定物理机的某个ip 且ip是随机的

    docker run --name t3 -it -p 172.30.0.14::80 --rm wang/httpd:v0.2

  指定绑定容器的80端口到物理机的80:

    docker run --name t3 -it -p 80:80 --rm wang/httpd:v0.2

  即指定端口又指定ip:

    docker run --name t3 -it -pip:80:80 --rm wang/httpd:v0.2

    

  

联盟还是容器(让两个容器共享一个名称空间) Joined container

  两个名称空间各自使用自己的User Mount  Pid,  共享UTS Net 和IPC

共享其他容器的网络名称空间:

  docker run --name b6 --network container:b5 -it --rm busybox

共享主机的地址给容器:

  docker run --name b5 --network host -it --rm busybox

配置修改docker默认的ip地址段

  直接在/etc/docker/daemon.json 文件添加

  "bip":"ip/掩码",   其余的会根据ip自动生成

在docker远程连接其他docker (默认不可以,因为docker默认监听的是本地的unit协议)

  需要修改监听一个正常的tcp监听端口即可,也是在/etc/docker/daemon.json 文件添加

    "hosts":["tcp://0.0.0.0:2375", "unix":///var/run/docker.sock]

  远程连接: docker -H ip:375 command

根据需求添加网络:

  docker network create -d bridge --subnet "172.26.0.0/16" --gateway "172.26.0.1" mybr0

创建容器时 把网络加到自己创建到ip段里面:

  docker run --name t5 -it --rm --net mybr0 busybox

docker 第四篇 网络的更多相关文章

  1. [docker]docker的四种网络方式

    声明: 本博客欢迎转发,但请保留原作者信息! 博客地址:http://blog.csdn.net/halcyonbaby 内容系本人学习.研究和总结,如有雷同,实属荣幸! bridge方式(默认) H ...

  2. docker的四种网络模式

    /* 1. host模式 : docker run 使用 --net=host指定 docker使用的网络实际上和宿主机一样 2. container模式: 使用 --net=container:co ...

  3. Python之路(第三十四篇) 网络编程:验证客户端合法性

    一.验证客户端合法性 如果你想在分布式系统中实现一个简单的客户端链接认证功能,又不像SSL那么复杂,那么利用hmac+加盐的方式来实现. 客户端验证的总的思路是将服务端随机产生的指定位数的字节发送到客 ...

  4. Docker——四种网络模式

    docker run创建Docker容器时,可以用–net选项指定容器的网络模式,Docker有以下4种网络模式:  bridge模式:使用–net =bridge指定,默认设置:  host模式 ...

  5. docker+k8s基础篇四

    Docker+K8s基础篇(四) pod控制器 A:pod控制器类型 ReplicaSet控制器 A:ReplicaSet控制器介绍 B:ReplicaSet控制器的使用 Deployment控制器 ...

  6. JDownload: 一款可以从网络上下载文件的小程序第四篇(整体架构描述)

    一 前言 时间过得真快,距离本系列博客第一篇的发布已经过去9个月了,本文是该系列的第四篇博客,将对JDownload做一个整体的描述与介绍.恩,先让笔者把记忆拉回到2017年年初,那会笔者在看Unix ...

  7. python学习之路网络编程篇(第四篇)

    python学习之路网络编程篇(第四篇) 内容待补充

  8. [转帖]Docker四种网络模式

    Docker(十四)-Docker四种网络模式 https://www.cnblogs.com/zhuochong/p/10069293.html 计算机网络相关的知识 非常有用.. Docker 安 ...

  9. Docker学习第四天(Docker四种网络模式)

    Docker四种网络模式 实现原理 Docker使用Linux桥接(参考<Linux虚拟网络技术>),在宿主机虚拟一个Docker容器网桥(docker0),Docker启动一个容器时会根 ...

随机推荐

  1. ubuntu18 bluebooth

    QDBusPendingReply: type ManagedObjectList is not registered with QtDBus 19:36:14: The program has un ...

  2. 【论文笔记】DeepOrigin: End-to-End Deep Learning for Detection of New Malware Families

    DeepOrigin: End-to-End Deep Learning for Detection of New Malware Families 标签(空格分隔): 论文 论文基本信息 会议: I ...

  3. SQL Server 高级函数汇总【转】

    看到一个帖子,博主收集的很全,里面涵盖了一些常用的内置函数,特此收藏下: 原文链接:https://blog.csdn.net/wang1127248268/article/details/53406 ...

  4. iOS-MMDrawerController的使用【抽屉视图+(SUNSlideSwitchView)进度条手势滑动】转

    下载网站:https://github.com/mutualmobile/MMDrawerController 首先,到下载网址下载MMDrawerController,将文件导入工程,里面有: MM ...

  5. Java工程师学习指南第5部分:Java网络编程与NIO

    本文整理了微信公众号[Java技术江湖]发表和转载过的Java网络编程相关优质文章,想看到更多Java技术文章,就赶紧关注本公众号吧. 深度解读 Tomcat 中的 NIO 模型 [Java基本功]浅 ...

  6. AssassinGo: 基于Go的高并发可拓展式Web渗透框架

    转载自FreeBuf.COM AssassinGo是一款使用Golang开发,集成了信息收集.基础攻击探测.Google-Hacking域名搜索和PoC批量检测等功能的Web渗透框架,并且有着基于Vu ...

  7. 部署zabbix监控平台(源码安装)

    案例:部署Zabbix监控平台 1 问题 本案例要求部署一台Zabbix监控服务器,一台被监控主机,为进一步执行具体的监控任务做准备: 安装LNMP环境 源码安装Zabbix 安装监控端主机,修改基本 ...

  8. C#实现多线程的方式:Task——任务

    简介 .NET 4包含新名称空间System.Threading.Tasks,它 包含的类抽象出了线程功能. 在后台使用ThreadPool. 任务表示应完成的某个单元的工作. 这个单元的工作可以在单 ...

  9. storm1.2.2集群搭建

    一.下载.解压 二.配置安装 1.配置分配 1.zk的集群分别在:192.168.100.143  192.168.100.144  192.168.100.145 三台服务器上, zk集群的安装说见 ...

  10. 【转帖】MBW内存测试

    MBW内存测试 https://www.cnblogs.com/dongdongwq/p/5431561.html 在测试前,理应了解本机所具备的特点,比如CPU频率.内存频率.内存大小,等等信息. ...