Docker实战:利用commit命令构建镜像

文章目录

    1. 实战概述
    1. 实战步骤
    • 2.1 下载Nginx镜像
    • 2.2 创建并启动Nginx容器
    • 2.3 修改Nginx主页文件
      • 2.3.1 备份主页文件
      • 2.3.2 修改主页内容
    • 2.4 启动Nginx服务
    • 2.5 访问Nginx主页
    • 2.6 停止Nginx服务并退出容器
    • 2.7 利用commit命令构建新镜像
    • 2.8 利用新镜像生成容器并测试
    1. 实战总结

1. 实战概述

  • 本实战围绕 docker 部署 nginx 展开,通过拉取最新 nginx 镜像,创建并启动交互式容器,备份并修改默认主页文件,启动 nginx 服务验证访问效果,再通过 commit 命令将修改后的容器构建为新镜像,最后基于新镜像创建容器并测试,完成 nginx 容器的自定义与复用。

2. 实战步骤

2.1 下载Nginx镜像

  • 执行命令:docker pull nginx:latest

2.2 创建并启动Nginx容器

  • 执行命令:docker run --name hw-nginx -p 8080:80 -it nginx:latest /bin/bash

2.3 修改Nginx主页文件

2.3.1 备份主页文件

  • 执行命令:cp /usr/share/nginx/html/index.html /usr/share/nginx/html/index.html.bak

2.3.2 修改主页内容

  • 执行命令:echo "<h1>Welcome to Nginx World~</h1>" > /usr/share/nginx/html/index.html

2.4 启动Nginx服务

  • 执行命令:nginx -g "daemon off;"

2.5 访问Nginx主页

  • 访问:http://euler01:8080

2.6 停止Nginx服务并退出容器

  • Ctrl + C停止Nginx服务,再执行命令:exit,退出容器

2.7 利用commit命令构建新镜像

  • 执行命令:docker commit hw-nginx hw-nginx:v1
  • 执行命令:docker images hw*

2.8 利用新镜像生成容器并测试

  • 执行命令:docker run --name test-hw-nginx --hostname master -p 8888:80 -it hw-nginx:v1 /bin/bash
  • 执行命令:nginx -g "daemon off;"
  • 访问http://euler01:8888

3. 实战总结

  • 本次实战完整实现了docker中nginx容器的自定义部署流程。从拉取镜像、创建交互式容器,到修改主页内容并验证访问,步骤清晰可复现。通过docker commit将修改后的容器封装为新镜像,解决了容器重启后修改丢失的问题。基于新镜像创建的容器可直接复用自定义配置,测试访问成功。需注意,启动nginx服务时需使用-g "daemon off;"参数保证前台运行,且通过docker images hw*可快速筛选目标镜像,提升操作效率。
相关推荐
雪可问春风16 小时前
docker环境部署
运维·docker·容器
双份浓缩馥芮白17 小时前
【Docker】Linux 迁移 docker 目录(软链接)
linux·docker
kobe_OKOK_18 小时前
S7 adapter Docker run
运维·docker·容器
一个欠登儿程序员18 小时前
在国产服务器上通过 Docker 部署 Windows 虚拟机
服务器·windows·docker
Hadoop_Liang19 小时前
构建Spring Boot项目Docker镜像
spring boot·后端·docker
Learn-Python21 小时前
修改docker容器内文件后让其生效
运维·docker·容器
赵丙双1 天前
docker restart 策略
docker·restart
工具罗某人1 天前
docker实现redis-cluster模式集群部署
java·redis·docker
杨浦老苏1 天前
轻量级RSS源处理中间件FeedCraft
人工智能·docker·ai·群晖·rss
Devin~Y1 天前
大厂 Java 面试实战:从电商微服务到 AI 智能客服(含 Spring 全家桶、Redis、Kafka、RAG/Agent 解析)
java·spring boot·redis·elasticsearch·spring cloud·docker·kafka