【Docker进阶-05】Docker网络

【Docker进阶-05】Docker网络

端口映射

bash 复制代码
docker create -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 --name hello-mysql mysql:5.7

容器互联(不推荐)

--link name:alias ,name连接容器的名称,alias连接的别名

场景:我们无需暴露mysql的情况下,让web应用使用mysql;

bash 复制代码
docker run -d -e MYSQL_ROOT_PASSWORD=123456 --name mysql01 mysql:5.7
docker run -d --link mysql01:mysql --name tomcat tomcat:7
docker exec -it tomcat bash
cat /etc/hosts
ping mysql
bash 复制代码
docker run -d -P --name=tomcat1 --link=redisserver tomcat:jre8-alpine
进入tomcat1后,ping redisserver

link 这种方式容器启动的时候,会查询--link的容器的ip并写死到当前容器的/etc/hosts下面;而且是单向的,对方并不知道我的存在;

问题:redisserver ip地址变了不会更新。

所以不推荐

自定义网络

默认网络原理

Docker使用Linux桥接,在宿主机虚拟一个Docker容器网桥(docker0),Docker启动一个容器时会根据Docker网桥的网段分配给容器一个IP地址,称为Container-IP,同时Docker网桥是每个容器的默认网关。

因为在同一宿主机内的容器都接入同一个网桥,这样容器之间就能够通过容器的Container-IP直接通信。

Docker容器网络就很好的利用了Linux虚拟网络技术,在本地主机和容器内分别创建一个虚拟接口,并让他们彼此联通(这样一对接口叫veth pair);

Docker中的网络接口默认都是虚拟的接口。虚拟接口的优势就是转发效率极高(因为Linux是在内核中进行数据的复制来实现虚拟接口之间的数据转发,无需通过外部的网络设备交换),对于本地系统和容器系统来说,虚拟接口跟一个正常的以太网卡相比并没有区别,只是他的速度快很多。

原理:

1、每一个安装了Docker的linux主机都有一个docker0的虚拟网卡。桥接网卡

2、每启动一个容器linux主机多了一个虚拟网卡。

3、docker run -d -P --name tomcat --net bridge tomcat:8

网络模式

container模式:(事先启动一个名为redisserver的容器)docker run -it --network container:redisserver alpine

host模式:

推荐使用自定义模式:自定义网络模式下,可以用容器名访问

自建网络测试

bash 复制代码
#1、docker0网络的特点。,
默认、域名访问不通、--link 域名通了,但是删了又不行
bash 复制代码
#2、可以让容器创建的时候使用自定义网络,用自定义
1、默认default "bridge"
2、自定义创建一个网络网络
docker network create --driver bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynet
bash 复制代码
#3、跨网络连接别人就用。把tomcat加入到mynet网络
docker network connect [OPTIONS] NETWORK CONTAINER
docker network connect mynet tomcat

效果:
1、自定义网络,默认都可以用主机名访问通
2、跨网络连接别人就用 docker network connect mynet tomcat
bash 复制代码
#4、命令
1、容器启动,指定容器ip。 docker run --ip 192.168.0.3 --net 自定义网络
2、创建子网。docker network create --subnet 指定子网范围 --driver bridge 
3、docker compose 中的网络默认就是自定义网络方式。
docker run -d -P --network 自定义网络名(网络需提前创建)

对比

相关推荐
taxunjishu11 小时前
半导体晶圆制造车间 SITRANS P 仪表与 V90 伺服系统精密控制应用
网络·物联网·自动化
雷帝木木11 小时前
Flutter for OpenHarmony:Flutter 三方库 cbor 构建 IoT 设备的极致压缩防窃协议(基于标准二进制 JSON 表达格式)
网络·物联网·flutter·http·json·harmonyos·鸿蒙
齐齐大魔王11 小时前
虚拟机网络无法连接
linux·网络·c++·python·ubuntu
ht巷子12 小时前
boost.asio网络学习:Http Server
网络·c++·http
-许平安-12 小时前
MCP项目笔记三(server)
网络·c++·笔记·mcp
乾元12 小时前
安全官(CISO)的困惑:AI 投入产出比(ROI)的衡量
网络·人工智能·安全·网络安全·chatgpt·架构·安全架构
marsh020612 小时前
13 openclaw数据验证与过滤:确保应用安全性的第一道防线
网络·数据库·ai·编程·技术
终端鹿12 小时前
深度解析 WebSocket DevTools 插件
网络·websocket·网络协议
love530love12 小时前
Duix-Avatar 去 Docker Desktop 本地化完整复盘
人工智能·pytorch·windows·python·docker·容器·数字人
春日见12 小时前
Matlab快速入门 基础语法教学
java·开发语言·驱动开发·matlab·docker·计算机外设