docker小白第十二天

docker小白第十二天

docker network简介

docker不启动时默认的网络情况。

# 停止docker服务
systemctl stop docker.socket
systemctl stop docker
# 查看docker镜像
docker images

输入查看docker镜像命令后,显示未连接到docker服务器
在这里插入图片描述
docker启动时网络情况

systemctl start docker
docker images

可以看到很多镜像
在这里插入图片描述
此时在查看虚拟机当前的网卡情况,会有一个docker0的虚拟网桥。

ifconfig

在这里插入图片描述

# 查看docker 网络命令
docker network ls

安装完docker后,默认会自动创建三大网络模式,分别为bridge、host、none

在这里插入图片描述

# docker 查看网络命令帮助
docker network --help
# 查看某个网络信息
docker network inspect 网络名字

在这里插入图片描述
在这里插入图片描述

在这里插入图片描述

docker网络能干什么

在这里插入图片描述

docker网络模式

在这里插入图片描述

docker网络模式学习案例

# 新建两个ubuntu容器,命名为u1和u2并进入命令行界面
# exit是退出命令行界面,会直接关闭非后台守护式的进程
# ctrl+p+q 退出,任何后台进程均保留
docker run -it --name=u1 ubuntu /bin/bash
docker run -it --name=u2 ubuntu /bin/bash
# 查看已创建的镜像
docker ps

在这里插入图片描述

# 查看容器的网络模式
docker inspect u1

可以看到容器u1的ip、网关、网桥名。需要注意的是docker中的ip是动态分配的,即某个容器停止了或者被删除后,其ip将被紧接着新建的容器使用。
在这里插入图片描述

docker网络模式之bridge

# 查看docker网络列表
docker network ls
# 查看docker网络模式的网桥信息
docker network inspect bridge

在这里插入图片描述
在这里插入图片描述在这里插入图片描述

在这里插入图片描述

# 启动两个容器,端口分别为8081和8082
docker run -d -p 8081:8080 --name tomcat81 billygoo/tomcat8-jdk8
docker run -d -p 8082:8080 --name tomcat82 billygoo/tomcat8-jdk8
docker ps

观察到已经实际启动了两个容器
在这里插入图片描述
输入ip addr可以看到多了很多网卡信息
在这里插入图片描述
进入容器内部查看ip信息

docker exec -it tomcat81 bash
ip addr

可以看到17:eth0@if18,与在宿主机查看的18: vethbb23d64@if17相呼应。即宿主机上显示名称为veth,容器内部显示名称为eth0
在这里插入图片描述

network之host

直接使用宿主机的ip地址与外界进行通信, 不在需要额外进行NAT转换。在这里插入图片描述

# 以host网络模式创建一个后台守护式的容器
docker run -d -p 8083:8080 --network host --name tomcat83 billygoo/tomcat8-jdk8

发现出现一个警告,而且docker ps查看并没有出现像之前一样的0.0.0.0:8083->8080/tcp,这样的一个映射关系。
在这里插入图片描述
在这里插入图片描述
那么此时删掉-p 的参数 重新建立一个容器tomcat8083

docker stop tomcat83
docker remove tomcat83
docker run -d --network host --name tomcat83 billygoo/tomcat8-jdk8
# 查看宿主机的网络情况
ip addr
# 查看容器tomcat83的网络情况
docker inspect tomcat83

在这里插入图片描述
可以看到因为是host模式,容器tomcat83没有自己的ip和网关。
在这里插入图片描述

# 进容器内部查看网络信息
docker exec -it tomcat83 bash
ip addr

可以看到容器内部输入ip addr时与宿主机的信息几乎一样
在这里插入图片描述
因为host模式没有设置-p容器的端口映射关系了,访问刚刚启动的tomcat83,只需要访问宿主机ip:8080端口即可,因为此时容器的ip借用宿主机的.

# 如果浏览器访问无效,关闭linux宿主机的防火墙
systemctl stop firewalld

在这里插入图片描述

网络模式之none

就是禁用网络功能,只有lo标识(就是127.0.0.1表示本地回环)在这里插入图片描述

# 建议一个网络模式为none的容器tomcat84
docker run -d -p 8084:8080 --network none --name tomcat84 billygoo/tomcat8-jdk8
docker ps

在这里插入图片描述
在容器外的宿主机上查看tomcat84网络信息

docker inspect tomcat84

在这里插入图片描述
进容器tomcat84内查看ip addr发现只有一个lo

docker exec -it tomcat84 bash
ip addr

在这里插入图片描述

网络模式之container

新创建的容器不会创建自己的网卡和配置自己的IP,而是和一个指定的容器共享IP、端口范围等。
在这里插入图片描述

# 创建两个容器分别为tomcat85和tomcat86
docker run -d -p 8085:8080 --name tomcat85 billygoo/tomcat8-jdk8
# tomcat86借用tomcat85容器的网络
docker run -d -p 8086:8080 --network container:tomcat86 --name tomcat85 billygoo/tomcat8-jdk8

执行第二个命令报错,相当于tomcat86和tomcat85共用一个ip一个端口,导致端口冲突,使用tomcat镜像不合适。
在这里插入图片描述
使用Alpine操作系统进行案例演示。Alpine操作系统是一个面向安全的轻型linux发行版。

docker run -it --name alpine1 alpine /bin/sh
docker run -it --network container:alpine1 --name alpine2 alpine /bin/sh

在两个新建的容器内查看ip addr发现网卡信息是一样的
在这里插入图片描述
在这里插入图片描述
如果此时exit关闭退出alpine1容器,并docker stop alpine1,查看alpine2容器的信息如下。只剩了lo网卡信息。
在这里插入图片描述

网络模式之自定义网络模式

# 启动两个docker实例tomcat81 和tomcat82
docker run -d -p 8081:8080 --name tomcat81 billygoo/tomcat8-jdk8
docker run -d -p 8082:8080 --name tomcat82 billygoo/tomcat8-jdk8
# 进入容器内部
docker exec -it tomcat81 bash
docker exec -it tomcat82 bash

分别输入ip addr,查看两个容器ip,一个为172.17.0.2,一个为172.17.0.3.并且两个容器之间可以互相ping通
在这里插入图片描述
在这里插入图片描述
此时如果不是pingIP,而是ping服务名,则会变成unknown错误。因为ip在容器内是可能变换的,所以ping服务名更准确,但是需要自定义网络模式。

引入自定义桥接网络

自定义桥接网络,自定义网络默认使用的是桥接网络bridge。

# 创建一个自定义桥接网络,网络名字叫cc_network
docker network create cc_network
# 查看网络信息
docker network ls

在这里插入图片描述
新建容器加入自定义网络

# 删除上一步新建的两个容器,未使用自定义网络
docker stop tomcat81
docker stop tomcat82
docker rm -f tomcat81
docker rm -f tomcat82
# 新建容器加入自定义网络
docker run -d -p 8081:8080 --network cc_network --name tomcat81 billygoo/tomcat8-jdk8
docker run -d -p 8082:8080 --network cc_network --name tomcat82 billygoo/tomcat8-jdk8

进入新建的容器内部

docker exec -it tomcat81 bash
docker exec -it tomcat82 bash

ping容器名字

ping tomcat81

可以看到能ping通了,建议在使用docker集群环境下多个容器时,用ping容器名比较准确,
在这里插入图片描述
总结:自定义网络本身就维护好了主机名和ip的对应关系( ip和域名都能通,自定义网络提供自动dns解析,可以通过服务名调用)

  • 13
    点赞
  • 17
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值