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 / 自定义网桥)三大核心组件协同实现

相关推荐
虫小宝2 小时前
电商返利APP容器编排实践:K8s在多环境部署中的资源调度优化
云原生·容器·kubernetes
苹果醋32 小时前
vue + iview + vue-i18n中英翻译
java·运维·spring boot·mysql·nginx
QH_ShareHub2 小时前
SSH 隧道:如何让本机借用服务器网络
运维·ssh·php
网硕互联的小客服2 小时前
服务器中的IPV4和IPV6有什么区别?那个比较好?
运维·服务器·ip
Teable任意门互动2 小时前
飞书多维表格vsTeable 如何选?把握“内外兼修”是关键决策点
运维·自动化·飞书·数据库开发·wps
bing_feilong2 小时前
ubuntu如何开机运行一个python3脚本?
linux·运维·ubuntu
Autumn72992 小时前
超算 HPC使用 (集群1):SSH免密登录
运维·ssh
真正的醒悟2 小时前
AI中的网络世界
运维·服务器·网络
G31135422732 小时前
服务器之IP地址与域名之间的绑定
运维·服务器·tcp/ip