docker网络实践
docker网络.md
#docker 网络模式
环境 centos7.4 , Docker version 17.12.0-ce
docker自带网络类型 bridge,host,none,container,overlay,macvlan
#本地网络
bridge # --net=bridge 默认模式,NAT转发
host # --net=host 使用宿主机网络
container # --net=container:容器名或ID ,共用其它容器网络
none # --net=none 无网卡
#跨主机网络
overlay #vxlan模式
macvlan #使用外部lan,需手动配置
#可以使用其它网络插件
#查看docker网络
docker network ls
#docker修改本地默认网段
#docker启动默认创建docker0网桥172.17网段
#添加自定义网段
SetOPTS=" --bip=192.168.55.1/24"
sed -i "s#^ExecStart.*#& $SetOPTS #" /usr/lib/systemd/system/docker.service
grep 'ExecStart' /usr/lib/systemd/system/docker.service
#重启docker
systemctl daemon-reload
systemctl restart docker
ifconfig docker0 |egrep 'inet |flags' #查看docker0网桥ip已改
#可使用自定义网桥,创建br0,修改配置 -b=br0
#docker本地网络实践
#不指定网络,使用默认bridge
docker run -dit --name busybox1 busybox
docker exec -it busybox1 ifconfig #查看网络
#host网络
docker run -dit --name busybox-host --net=host busybox
docker exec -it busybox-host ifconfig #查看网络,与宿主机一样
#container网络
docker run -dit --name busybox2 --net=container:busybox1 busybox #使用busybox1网络
docker exec -it busybox1 ifconfig #查看网络
#none没网络
docker run -dit --name busybox-none --net=none busybox
docker exec -it busybox-none ifconfig
#创建本地网络mynet1(自定义网络能设置固定ip)
docker network create --subnet 192.168.58.0/24 --gateway 192.168.58.1 mynet1
docker run -dit --name busybox3 --network mynet1 --ip=192.168.58.18 busybox
docker exec busybox3 ifconfig |egrep 'inet|flags' #查看容器网络
#docker 容器 添加网卡
docker network connect mynet1 --ip 192.168.58.8 busybox1 #给容器添ip
docker exec $(docker ps -l -q) ifconfig |egrep 'inet|flags' #查看网络
docker network disconnect mynet1 busybox1 #断开网络,再次查看网络……
#删除测试容器、网络
docker rm -f busybox1 busybox2 busybox3 busybox-host busybox-none
docker network rm mynet1
#docker跨主机通信
#overlay网络
本次在docker swarm集群操作
创建docker swarm 集群参考http://www.cnblogs.com/elvi/p/8424378.html
docker swarm集群创建容器,会自动创建overlay网络ingress
docker network ls #查看网络
#创建overlay类型网络mynet2,并设置网段、网关
docker network create -d overlay --subnet 192.168.59.0/24 --gateway 192.168.59.1 mynet2
docker network inspect mynet2 #查看网络参数
#swarm集群使用自定义网段mynet2
docker service create --name nginx2 --replicas 2 \
-p 81:80 --network mynet2 hub.test.com:5000/almi/nginx:0.1
#hub.test.com:5000/almi/nginx:0.1 为内网私有仓库镜像
docker service ls
#swarm集群创建容器默认2个网卡,增加了自定义网卡
docker exec $(docker ps -l -q) ifconfig |egrep 'inet|flags' #查看网络
#删除测试
docker service rm nginx2
docker network rm mynet2
docker network prune #删除未使用的网卡
# macvlan网络
#宿主机开启网卡混杂模式
ip link set eth0 promisc on
ifconfig eth0 |egrep 'inet |flags'
#创建macvlan模式网络macnet
docker network create -d macvlan -o parent=eth0 macnet \
--subnet 172.16.50.0/24 --gateway 172.16.50.1
#创建容器
docker run -d --name nginx3 --net macnet hub.test.com:5000/almi/nginx:0.1
docker exec nginx3 ping -c 4 nginx3 #测试获取ip成功
#其它docker节点创建网络、容器,然后ping测试
#删除测试
docker rm -f $(docker ps -l)
docker network rm macnet
本次macvlan测试环境为虚拟机,获取外部vlan失败
宿主机配置vlan网络+macvlan模式,实现docker vlan网络
使用macvlan,无法与宿主机通信
docker网络实践的更多相关文章
- docker 网络实践
#docker 网络模式 环境 centos7. , Docker version -ce docker自带网络类型 bridge,host,none,container,overlay,macvla ...
- Docker网络实践运用
Docker 容器网络概述 要构建具有安全的一致行为的 Web 应用程序,可以使用 Docker 网络特性.根据定义,网络为容器实现了完全隔离.因此,控制应用程序所在的网络很重要.Docker 容器网 ...
- 【转】Docker网络详解及pipework源码解读与实践
好文必转 原文地址: http://www.infoq.com/cn/articles/docker-network-and-pipework-open-source-explanation-prac ...
- Docker 网络详解及 pipework 源码解读与实践
转载自:https://www.infoq.cn/article/docker-network-and-pipework-open-source-explanation-practice/ Docke ...
- Docker网络模式
[编者的话] 本文是<Docker网络及服务发现>一书的一个章节,介绍了搭建Docker单主机网络的基础内容.关于Docker网络的更多内容,包括多主机的网络,请参考该书的其他章节. @C ...
- Docker网络解决方案-Flannel(转)
转自https://www.cnblogs.com/kevingrace/p/6859114.html Docker跨主机容器间网络通信实现的工具有Pipework.Flannel.Weave.Ope ...
- docker 网络的几种模式
docker 网络分为单机和多机,我们来了解一下docker的单机网络 docker单机网络分为以下几种: 1)bridge NetWork,使用--net=bridge指定,默认设置.2)Host ...
- Docker 网络基础介绍
[编者按]本文作者为 Mesosphere 开发大使 Michael Hausenblas,主要介绍配置 Docker 单主机网络的基本知识.文章系国内 ITOM 管理平台 OneAPM 编译呈现. ...
- Docker网络一览
转自:http://dockone.io/article/1143 [编者的话]本文是Nuage Networks公司Filip Verloy的一篇博文,简介了一下Docker网络情况,单主机的四种模 ...
随机推荐
- Spring AOP注解通过@Autowired,@Resource,@Qualifier,@PostConstruct,@PreDestroy注入属性的配置文件详解
本文介绍了使用Spring注解注入属性的方法.使用注解以前,注入属性通过类以及配置文件来实现.现在,注入属性可以通过引入@Autowired注解,或者@Resource,@Qualifier,@Pos ...
- WINDOWS中设置计划任务执行PHP文件
1.写一个PHP程序,命名为test.php,内容如下所示: <? $fp = fopen("test.txt", "a+"); fwrite($fp, ...
- C++ 引用基础
//引用 #include<iostream> using namespace std; struct Student{ ]; int age; }; struct Teacher{ in ...
- 8天学通MongoDB(mark)
转自:http://www.cnblogs.com/huangxincheng/archive/2012/02/18/2356595.html 关于mongodb的好处,优点之类的这里就不说了,唯一要 ...
- 关于Unity中的几何体,材质和FBX模型
一.创建几何体的类型 1: 创建平面 Plane;2: 创建立方体 Cube;3: 创建球体 Sphere;4: 创建胶囊体 Capsule;5: 创建圆柱体 Cylinder;6: 3D文字 3D ...
- 文件 I/O 问题
文件 I/O 问题:(1)对不存在的或者错误的文件进行操作吗?(2)文件以不正确的方式打开吗?(3)文件结束判断不正确吗?(4)没有正确地关闭文件吗? #include <iostream> ...
- 【BZOJ】1669: [Usaco2006 Oct]Hungry Cows饥饿的奶牛(lis)
http://www.lydsy.com/JudgeOnline/problem.php?id=1669 水题太严重 #include <cstdio> #include <cstr ...
- jQuery动态星级评分效果实现方法
本文实例讲述了jQuery动态星级评分效果实现方法.分享给大家供大家参考.具体如下: 这里的jQuery星级评分代码,是大家都很喜欢的功能,目前广泛应用,本星级评分加入了动画效果,注意,如果要真正实现 ...
- v8随心记
因为node原因,研究v8已经有段时间了,但是一直也没有抽空写点什么,现在想想有好多当时清晰的东西又模糊了.哎,伤心的很啊.但是一时又想不起什么章法,所以只能随手胡乱写了. 下载.编译: https: ...
- hdu 4496(并查集)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=4496. 思路:简单并查集应用,从后往前算就可以了. #include<iostream> ...