news 2026/4/5 3:17:39

Docker 生产环境容器化

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Docker 生产环境容器化

场景 1:上线发布(创建+启动合并,后台运行)

任务 1.1:用 nginx 镜像创建并启动容器(后台运行)

要求:

  • 容器名:web-prod-01

  • 端口映射:宿主机43000映射容器80

  • 后台运行:必须使用-d

结果:

场景 2:基础操作(创建、启动、停止、查看)

任务 2.1:使用 docker create 创建容器(默认停止)

要求:

  • 使用docker create -it nginx:latest /bin/bash(或按你环境可用镜像)

  • 证明容器状态是Created

提交证据:

  • docker ps -a输出(状态为 Created)

任务 2.2:启动该容器并查看状态

提交证据:

  • docker start <容器ID或名称>命令

  • docker ps -a输出(状态为 Up 或 Exited 需解释原因)

任务 2.3:停止容器

  • docker stop <容器ID或名称>

  • docker ps -a输出(状态为 Exited)

任务 3.1:进入 web-prod-01 容器执行命令

要求进入容器执行:

  • ls

  • cat /etc/os-release(若镜像无该文件,可换uname -a

场景 4:文件复制(主机↔容器)

任务 4.1:把宿主机文件复制到容器

要求:

  1. 在宿主机创建文件~/test.txt,内容为员工编号+姓名(例:2025xxx 张三

  2. 复制到容器/opt/目录

任务 4.2:从容器复制回宿主机

要求:

  • 从容器复制/opt/test.txt到宿主机~/abc123.txt

场景 5:容器迁移(导出与导入)

任务 5.1:导出容器为 tar 包

要求:

  • 导出web-prod-01web-prod-01.tar

任务 5.2:导入 tar 包生成新镜像

要求:

  • 镜像名:web-import:test

说明题(必答):export/importsave/load有什么区别?(写 3 句话以内)

export/import 操作的是容器

save/load操作的是镜像

export丢弃镜像历史,save保留完整层信息;

场景 6:下线与清理(删除与批量删除)

任务 6.1:删除指定容器

要求:

  • 停止并删除web-prod-01

任务 6.2:批量停止所有容器(两种方式任选其一)

任选提交一种:

  1. docker stop $(docker ps -q)

  2. docker ps -a | awk ... | xargs docker stop

任务 6.3:删除所有容器

任选提交一种:

  1. docker rm -f $(docker ps -aq)

  2. docker ps -a | awk ... | xargs docker rm

任务 6.4:批量删除镜像(两种方式任选其一)

任选一种:

  1. 删除所有镜像:docker rmi -f $(docker images -q)

  2. 只删除 none 镜像:docker images | grep none | ...

安全说明(必答): 为什么生产环境不建议直接执行“删除所有容器/镜像”?写出 2 点原因。

误删正在运行的业务容器,导致服务中断

镜像可能是其他容器依赖的基础 导致后续部署失败

三、网络部分


Docker 网络模式场景化作业

实验说明

  • 实验环境:单台 Linux 主机(物理机/虚拟机均可)

  • 镜像建议:nginxcentos:7

  • 禁止使用--network none

  • 每个场景必须执行命令并给出验证结果


场景一:bridge 模式(默认模式)——Web 服务对外发布

场景背景(生产化)

公司在一台服务器上部署多个 Web 服务,需要:

  • 容器之间相互隔离

  • 对外通过端口映射提供服务

这是最常见的生产 Docker 网络模式

任务 1.1:使用 bridge 模式运行 nginx

任务 1.2:查看容器 IP

思考题(必答)

1️⃣ 为什么外部不能直接访问容器 IP? 2️⃣ bridge 模式下端口映射的作用是什么?

①Docker网桥是宿主机虚拟出来的,并不是真实存在的网络设备,外部网络是无法寻址到的,这也意味着外部网络无法直接通过 Container-IP 访问到容器

② 将宿主机端口转发到容器端口。使得外部可通过宿主机IP访问服务


场景二:host 模式——高性能服务部署

场景背景(生产化)

公司部署一个高性能 Web 服务/监控服务

  • 对网络性能敏感

  • 不希望端口映射带来额外开销

因此直接让容器使用宿主机网络。


任务 2.1:使用 host 网络模式启动 nginx

①host模式下,容器有没有独立ip

答:host模式下容器没有独立 IP,共享宿主机的ip和端口

②host模式下适合什么类型的应用

适合高性能、低延迟应用

③host 模式的安全风险是什么?

容器直接暴露宿主机端口 ,无网络隔离,容易收到攻击

场景三:container 模式——紧密耦合服务(Sidecar)

场景背景(生产化)

某系统由两个组件组成:

  • 主服务(Service)

  • 辅助服务(日志/监控/代理)

要求:

  • 两个容器共享网络

  • 使用localhost通信

任务 3.1:启动主容器

任务 3.2:查看主容器网络命名空间

任务 3.3:启动共享网络的辅助容器

任务 3.4:对比两个容器的网络

1️⃣ container 模式与 host 模式的区别?

container 模式 共享另一个主机容器的命名空间 host共享主机

2️⃣ 为什么称这种模式为 Sidecar(边车模式)?

辅助容器像边车一样依附于主容器 共享网络、日志等资源,为核心服务提供辅助功能(如日志收集、代理)。

场景四:自定义 bridge 网络——多容器系统与固定 IP

场景背景(生产化)

公司部署一个多服务系统:

  • Web + App + DB

  • 需要:

    • 容器间直连

    • 可指定 IP

    • 网络与其他项目隔离


任务 4.1:创建自定义网络

任务 4.2:在自定义网络中启动容器

任务 4.3:容器间通信测试


1️⃣ 为什么默认 bridge 不能指定 IP?

默认 bridge 网络未启用固定 IP 分配功能,自定义网络支持手动指定子网和 IP

2️⃣ 自定义网络适合什么场景?

bridge 单机网络模式适合在一台宿主机 内容器互联

overlay 跨主机容器互联 docker swarm

macvlan 容器像一台物理机一样 直接获取宿主机的所在的网络的IP

3️⃣ Docker 如何实现容器间二层通信?

二层通信本质是基于数据链路层(MAC 地址)的通信,Docker 主要通过 网络命名空间、虚拟网络设备(veth pair)、网桥(docker0 / 自定义网桥)三大核心组件协同实现

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/4/2 13:38:26

Windows 11 24H2 LTSC微软商店恢复终极指南

Windows 11 24H2 LTSC微软商店恢复终极指南 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore 在企业级部署和个人使用环境中&#xff0c;Windows 11 24H…

作者头像 李华
网站建设 2026/3/26 23:27:08

解锁《星露谷物语》隐藏宝藏:StardewXnbHack带你玩转游戏资源

解锁《星露谷物语》隐藏宝藏&#xff1a;StardewXnbHack带你玩转游戏资源 【免费下载链接】StardewXnbHack A simple one-way XNB unpacker for Stardew Valley. 项目地址: https://gitcode.com/gh_mirrors/st/StardewXnbHack 你是否曾经盯着《星露谷物语》里那些可爱的…

作者头像 李华
网站建设 2026/3/28 21:55:38

Steam游戏清单自动下载:5分钟快速上手终极指南

还在为手动查找Steam游戏清单而烦恼吗&#xff1f;Onekey Steam Depot清单下载工具让这一切变得简单。这款开源工具专为游戏玩家设计&#xff0c;只需输入游戏App ID&#xff0c;就能自动从Steam官方服务器获取完整的游戏清单数据&#xff0c;彻底告别繁琐的手动操作流程。 【免…

作者头像 李华
网站建设 2026/3/29 3:08:23

Vue3地图组件化实践:从困境突破到优雅集成

Vue3地图组件化实践&#xff1a;从困境突破到优雅集成 【免费下载链接】vue3-google-map A set of composable components for easy use of Google Maps in your Vue 3 projects. 项目地址: https://gitcode.com/gh_mirrors/vu/vue3-google-map 当传统地图集成遇上现代前…

作者头像 李华
网站建设 2026/4/1 20:19:55

Windows 11 24H2 LTSC终极指南:5分钟快速恢复微软商店完整功能

Windows 11 24H2 LTSC终极指南&#xff1a;5分钟快速恢复微软商店完整功能 【免费下载链接】LTSC-Add-MicrosoftStore Add Windows Store to Windows 11 24H2 LTSC 项目地址: https://gitcode.com/gh_mirrors/ltscad/LTSC-Add-MicrosoftStore Windows 11 24H2 LTSC版本凭…

作者头像 李华
网站建设 2026/3/27 3:37:00

22、办公软件操作指南:Word、Excel、Access与PowerPoint

办公软件操作指南:Word、Excel、Access与PowerPoint 在当今数字化办公的时代,熟练掌握办公软件是提升工作效率和质量的关键。以下将详细介绍Word、Excel、Access和PowerPoint这四款常用办公软件的相关操作和功能。 1. 数据文件列表 1.1 Word数据文件 Word的数据文件丰富多…

作者头像 李华