热门标签 | 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

推荐阅读
  • 使用Vultr云服务器和Namesilo域名搭建个人网站
    本文详细介绍了如何通过Vultr云服务器和Namesilo域名搭建一个功能齐全的个人网站,包括购买、配置服务器以及绑定域名的具体步骤。文章还提供了详细的命令行操作指南,帮助读者顺利完成建站过程。 ... [详细]
  • 本文详细介绍了如何在Linux系统上安装和配置Smokeping,以实现对网络链路质量的实时监控。通过详细的步骤和必要的依赖包安装,确保用户能够顺利完成部署并优化其网络性能监控。 ... [详细]
  • MySQL索引详解与优化
    本文深入探讨了MySQL中的索引机制,包括索引的基本概念、优势与劣势、分类及其实现原理,并详细介绍了索引的使用场景和优化技巧。通过具体示例,帮助读者更好地理解和应用索引以提升数据库性能。 ... [详细]
  • 本文介绍如何在现有网络中部署基于Linux系统的透明防火墙(网桥模式),以实现灵活的时间段控制、流量限制等功能。通过详细的步骤和配置说明,确保内部网络的安全性和稳定性。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • CentOS7源码编译安装MySQL5.6
    2019独角兽企业重金招聘Python工程师标准一、先在cmake官网下个最新的cmake源码包cmake官网:https:www.cmake.org如此时最新 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • DNN Community 和 Professional 版本的主要差异
    本文详细解析了 DotNetNuke (DNN) 的两种主要版本:Community 和 Professional。通过对比两者的功能和附加组件,帮助用户选择最适合其需求的版本。 ... [详细]
  • MQTT技术周报:硬件连接与协议解析
    本周开发笔记重点介绍了在新项目中使用MQTT协议进行硬件连接的技术细节,涵盖其特性、原理及实现步骤。 ... [详细]
  • MySQL缓存机制深度解析
    本文详细探讨了MySQL的缓存机制,包括主从复制、读写分离以及缓存同步策略等内容。通过理解这些概念和技术,读者可以更好地优化数据库性能。 ... [详细]
  • 基于KVM的SRIOV直通配置及性能测试
    SRIOV介绍、VF直通配置,以及包转发率性能测试小慢哥的原创文章,欢迎转载目录?1.SRIOV介绍?2.环境说明?3.开启SRIOV?4.生成VF?5.VF ... [详细]
  • 微软Exchange服务器遭遇2022年版“千年虫”漏洞
    微软Exchange服务器在新年伊始遭遇了一个类似于‘千年虫’的日期处理漏洞,导致邮件传输受阻。该问题主要影响配置了FIP-FS恶意软件引擎的Exchange 2016和2019版本。 ... [详细]
  • 作者:守望者1028链接:https:www.nowcoder.comdiscuss55353来源:牛客网面试高频题:校招过程中参考过牛客诸位大佬的面经,但是具体哪一块是参考谁的我 ... [详细]
  • 本文探讨了如何在日常工作中通过优化效率和深入研究核心技术,将技术和知识转化为实际收益。文章结合个人经验,分享了提高工作效率、掌握高价值技能以及选择合适工作环境的方法,帮助读者更好地实现技术变现。 ... [详细]
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社区 版权所有