Docker入门--network(七)

我们分别搭建了两个容器,那么两个容器可以ping通吗?

tomcat  -----------------ping----------------------->  mysql

那么tomcat部署的war是怎么访问mysql数据库容器的?

docker每次重启都会改变容器的ip ,那么我们编写了一个微服务。项目不重启,数据库ip会改变,但是怎么保证容器名不变呢?

结合上面一连串的问题,首先先执行ping命令,看看两个容器可不可以互相ping通。

docker exec -it tomcat01 ping mysql01

tomcat01是镜像tomcat的容器,mysql01是镜像mysql的容器

执行结果可以ping不通,但是ping容器id可以ping通,ip应该也是可以ping通的,那么重启之后容器id就会变,唯一不变就是容器名称,所以这个怎么解决呢?

这里要介绍下Link命令,再次新建一个tomcat02容器,如下命令:

docker run -d -P --name tomcat03 --link tomcat02 --link mysql01 tomcat

再次执行

docker exec -it tomcat02 ping mysql01

可以ping通,通过看容器的/etc/hosts文件,发现其实是在容器的/etc/hosts里面写了主机名和ip的映射,所以能ping通

但是现在玩docker已经不建议使用 --link,接下来又要引入一个新的网络命令。

那么在Docker中还什么可以解决上述问题呢?

执行下面这条命令

docker network --help

可以看到下面列表

root@instance-6tmb40ht]# docker network --help

Commands:
	connect     	#连接一个容器到network
  	create      	#创建一个network
	disconnect  	#从network断开连接
  	inspect   		#展示详细信息通过一个或者更多network
  	ls          	#network列表
  	prune     		#移除所有不用的network
  	rm          	#删除一个或者多个network

create命令可以完美解决上述问题,创建一个名为mynet的network

docker network create --driver  bridge --subnet 192.168.0.0/16 --gateway 192.168.0.1 mynet

在这里插入图片描述
新建两个容器tomcat-net-01和tomcat-net-02

docker run -d -P --name tomcat-net-01 --net mynet tomcat
docker run -d -P --name tomcat-net-02 --net mynet tomcat

再使用如下命令,测试两个容器是否可以联通

docker exec -it tomcat-net-01 ping tomcat-net-02

在这里插入图片描述

查看mynet网络

docker network ls
docker network inspect mynet

在这里插入图片描述
两个容器在一个mynet里面,所以是通的,不仅仅这两个,只要是引用的mynet这个网络段都是可以互相联通的,所以在本命令尤其适合在集群或者多集群环境使用。

那么connect和disconnect命令是干什么用的呢?

顾名思义
一个独立于mynet之外的容器需要连接这个网络的时候,就需要这个命令了,如下面命令
docker network connect mynet tomcat01
那么反之,当不连接的时候,使用下面这个命令
docker network disconnect mynet tomcat01
### Docker 入门教程 Docker 是一种容器化技术,允许开发者创建、部署和运行分布式应用程序。它通过轻量级的虚拟化方式隔离应用及其依赖环境,从而实现跨平台一致性。 #### 什么是 DockerDocker 提供了一种标准化的方式来打包应用程序及其所有依赖项到一个可移植的容器中[^1]。这种容器可以在任何支持 Docker 的环境中运行,而无需担心底层系统的差异。 #### 安装 Docker 安装 Docker 需要根据操作系统版本选择合适的安装方法。对于 Linux 用户来说,可以通过包管理器完成安装;而对于 Windows 和 macOS,则可以下载官方提供的桌面版客户端[^2]。 #### 基本命令操作 - **查看 Docker 版本**: `docker version` 可用于确认当前使用的 Docker 版本信息。 - **启动服务**: 如果遇到问题或者需要重新加载配置文件时,可以用 `systemctl restart docker` 来重启 Docker 服务[^2]。 - **查询正在运行中的容器列表**: 使用 `docker ps` 能够快速了解哪些容器处于活动状态[^2]。 #### 创建并运行第一个容器实例 假设我们想要基于官方 Tomcat 镜像来启动一个新的 Web 应用程序服务器: ```bash docker pull tomcat:latest docker run -d -p 8080:8080 --name mytomcat tomcat:latest ``` 这里 `-d` 参数表示以后台模式运行该进程,同时将主机端口映射至容器内部指定的服务监听地址上[^1]。 #### 构建自定义镜像 当标准库无法满足特定需求时,就需要自己编写 Dockerfile 文件来自动生成定制化的镜像资源了。下面是一个简单的例子展示如何扩展 Ubuntu 系统以包含额外软件组件: ```Dockerfile FROM ubuntu RUN apt-get update && apt-get install -y curl git python3-pip CMD ["bash"] ``` 构建完成后可通过如下指令生成新镜像对象,并赋予其唯一标签以便后续引用调用[^3]: ```bash docker build -t custom/ubuntu . docker images ``` #### 数据持久化与网络设置 为了使数据不会因为容器销毁而丢失,通常会挂载本地目录作为存储卷的一部分参与其中。另外,在复杂场景下还需要考虑多个微服务之间相互通讯的需求,这时就可以利用用户定义桥接网路来进行连接规划[^4]: ##### 自定义 Redis 主从复制架构案例 主节点初始化脚本片段如下所示: ```bash docker run -d \ -v /path/to/master-data:/bitnami/redis/data \ -e ALLOW_EMPTY_PASSWORD=yes \ -e REDIS_REPLICATION_MODE=master \ --network redis-net \ --name redis-master \ bitnami/redis:latest ``` 同样地,也可以按照类似的方式去搭建附属副本节点并与前者建立关联关系. ##### MySQL 单机数据库示例 如果计划在一个独立进程中托管 SQL Server 实例的话,那么只需要简单执行以下几行代码即可达成目标效果: ```bash docker run -d \ -p 3306:3306 \ -v ~/mysql-conf.d:/etc/mysql/conf.d \ -v ~/mysql-data:/var/lib/mysql \ -e MYSQL_ROOT_PASSWORD=my-secret-pw \ mysql:tag ``` ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

京河小蚁

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值