热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Dockerfile编写与Docker网络配置详解

本文详细介绍了Dockerfile的编写方法及其在网络配置中的应用,涵盖基础指令、镜像构建与发布流程,并深入探讨了Docker的默认网络、容器互联及自定义网络的实现。

一. Dockerfile 编写指南


1. 常用指令解析


Dockerfile 是用于定义 Docker 镜像构建过程的文本文件。以下是常用的 Dockerfile 指令:


FROM # 指定基础镜像
MAINTAINER # 维护者信息(已弃用,建议使用 LABEL)
RUN # 构建时执行命令
ADD # 添加文件并自动解压(建议使用 COPY 代替)
WORKDIR # 设置工作目录
VOLUME # 挂载点
EXPOSE # 暴露端口
CMD # 容器启动时执行命令,默认可被替代
ENTRYPOINT # 容器启动时执行命令,通常配合 CMD 使用
ONBUILD # 当继承该镜像时触发
COPY # 添加文件到镜像中
ENV # 设置环境变量


2. 构建并发布 CentOS 镜像


以下是一个简单的例子,展示如何创建一个包含基本工具的 CentOS 镜像,并将其发布到 Docker Hub。


# 编写 Dockerfile 文件
FROM centos
LABEL maintainer="yqj"
ENV MYPATH /usr/local
WORKDIR $MYPATH
RUN yum -y install vim net-tools
EXPOSE 80
CMD ["/bin/bash"]

# 构建镜像
$ docker build -t yqj/centos:1.0 .

# 查看构建历史
$ docker history yqj/centos:1.0

# 启动容器
$ docker run -it --name mycentos01 yqj/centos:1.0

# 登录 Docker Hub
$ docker login -u yaokuku123

# 修改标签
$ docker tag yqj/centos:1.0 yaokuku123/centos:1.0

# 发布镜像
$ docker push yaokuku123/centos:1.0

# 退出登录
$ docker logout


3. 构建 Tomcat 镜像


接下来,我们将创建一个包含 JDK 和 Tomcat 的镜像。


# 准备文件:jdk-13.0.2_linux-x64_bin.tar.gz, apache-tomcat-8.5.53.tar.gz, readme.txt

# 编写 Dockerfile 文件
FROM centos
LABEL maintainer="yqj"
COPY readme.txt /usr/local/
COPY jdk-13.0.2_linux-x64_bin.tar.gz /usr/local/
COPY apache-tomcat-8.5.53.tar.gz /usr/local/
ENV MYPATH /usr/local
WORKDIR $MYPATH
ENV JAVA_HOME /usr/local/jdk-13.0.2
ENV CATALINA_HOME /usr/local/apache-tomcat-8.5.53
ENV CATALINA_BASE /usr/local/apache-tomcat-8.5.53
ENV PATH $PATH:$JAVA_HOME/bin:$CATALINA_HOME/lib:$CATALINA_HOME/bin
EXPOSE 8080
CMD ["/usr/local/apache-tomcat-8.5.53/bin/startup.sh", "&&", "tail", "-F", "/usr/local/apache-tomcat-8.5.53/logs/catalina.out"]

# 构建镜像
$ docker build -t yqj/tomcat:1.0 .

# 运行容器
$ docker run -d -p 8080:8080 --name mytomcat01 yqj/tomcat:1.0


二. Docker 网络配置


1. 默认网络模式


Docker 默认采用桥接网络模式,通过 veth-pair 技术连接主机和容器。每次启动容器时,Docker 会为容器分配一个 IP 地址,默认情况下使用的是 docker0 网桥。


# 创建一个 Tomcat 容器并查看其 IP 地址
$ docker run -d -p 8080:8080 --name mytomcat01 tomcat:9.0
$ docker exec -it mytomcat01 ip addr

# 在主机上查看网络接口
$ ip addr

# 尝试从主机 ping 容器 IP
$ ping 172.17.0.2

# 再启动一个容器并查看其 IP 地址
$ docker run -d -p 8081:8080 --name mytomcat02 tomcat:9.0
$ docker exec -it mytomcat02 ip addr

# 再次在主机上查看网络接口
$ ip addr

# 尝试从主机 ping 新容器 IP
$ ping 172.17.0.3

# 测试容器间互连通性
$ docker exec -it mytomcat01 ping 172.17.0.3
$ docker exec -it mytomcat02 ping 172.17.0.2

# 结论:容器之间以及主机与容器之间均可以互相通信


2. 容器互联 (--link)


为了简化容器间的通信,Docker 提供了 --link 参数,允许将容器名或 ID 映射到 IP 地址。但此方法现已不推荐使用,建议使用自定义网络。


# 启动一个新的容器并与 mytomcat02 联网
$ docker run -d -p 8082:8080 --name mytomcat03 --link mytomcat02 tomcat:9.0

# 测试 mytomcat03 是否能通过容器名访问 mytomcat02
$ docker exec -it mytomcat03 ping mytomcat02

# 查看 mytomcat03 的 hosts 文件
$ docker exec -it mytomcat03 cat /etc/hosts

# 查看 mytomcat02 的 hosts 文件
$ docker exec -it mytomcat02 cat /etc/hosts


3. 自定义网络


自定义网络提供了更灵活的网络隔离和管理方式,适用于集群环境。


# 查看当前网络配置
$ docker network ls

# 创建自定义网络
$ docker network create --driver bridge --subnet 192.167.0.0/16 --gateway 192.167.0.1 mynet

# 查看新网络详情
$ docker network inspect mynet

# 使用自定义网络启动两个 Tomcat 容器
$ docker run -d -P --name mytomcat-net-01 --net mynet tomcat:9.0
$ docker run -d -P --name mytomcat-net-02 --net mynet tomcat:9.0

# 再次查看自定义网络配置
$ docker network inspect mynet

# 测试容器间互连通性
$ docker exec -it mytomcat-net-01 ping mytomcat-net-02

# 测试不同网络下的容器互联
$ docker network connect mynet mytomcat01

# 再次查看自定义网络配置
$ docker network inspect mynet

# 测试不同网络下的容器是否可以互通
$ docker exec -it mytomcat01 ping mytomcat-net-01

# 删除自定义网络
$ docker network rm mynet

推荐阅读
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • 深入解析JVM垃圾收集器
    本文基于《深入理解Java虚拟机:JVM高级特性与最佳实践》第二版,详细探讨了JVM中不同类型的垃圾收集器及其工作原理。通过介绍各种垃圾收集器的特性和应用场景,帮助读者更好地理解和优化JVM内存管理。 ... [详细]
  • 本文介绍了Java并发库中的阻塞队列(BlockingQueue)及其典型应用场景。通过具体实例,展示了如何利用LinkedBlockingQueue实现线程间高效、安全的数据传递,并结合线程池和原子类优化性能。 ... [详细]
  • 本文详细介绍了IBM DB2数据库在大型应用系统中的应用,强调其卓越的可扩展性和多环境支持能力。文章深入分析了DB2在数据利用性、完整性、安全性和恢复性方面的优势,并提供了优化建议以提升其在不同规模应用程序中的表现。 ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 本文详细记录了在基于Debian的Deepin 20操作系统上安装MySQL 5.7的具体步骤,包括软件包的选择、依赖项的处理及远程访问权限的配置。 ... [详细]
  • Explore how Matterverse is redefining the metaverse experience, creating immersive and meaningful virtual environments that foster genuine connections and economic opportunities. ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • Java 中 Writer flush()方法,示例 ... [详细]
  • 本文介绍了如何使用 Spring Boot DevTools 实现应用程序在开发过程中自动重启。这一特性显著提高了开发效率,特别是在集成开发环境(IDE)中工作时,能够提供快速的反馈循环。默认情况下,DevTools 会监控类路径上的文件变化,并根据需要触发应用重启。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • python的交互模式怎么输出名文汉字[python常见问题]
    在命令行模式下敲命令python,就看到类似如下的一堆文本输出,然后就进入到Python交互模式,它的提示符是>>>,此时我们可以使用print() ... [详细]
  • 本文探讨了Hive中内部表和外部表的区别及其在HDFS上的路径映射,详细解释了两者的创建、加载及删除操作,并提供了查看表详细信息的方法。通过对比这两种表类型,帮助读者理解如何更好地管理和保护数据。 ... [详细]
  • 1.如何在运行状态查看源代码?查看函数的源代码,我们通常会使用IDE来完成。比如在PyCharm中,你可以Ctrl+鼠标点击进入函数的源代码。那如果没有IDE呢?当我们想使用一个函 ... [详细]
  • 数据管理权威指南:《DAMA-DMBOK2 数据管理知识体系》
    本书提供了全面的数据管理职能、术语和最佳实践方法的标准行业解释,构建了数据管理的总体框架,为数据管理的发展奠定了坚实的理论基础。适合各类数据管理专业人士和相关领域的从业人员。 ... [详细]
author-avatar
Coco李可儿
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有