docker教程:3.使用docker commit创建镜像

在实际的运用中,在docker hub中提供的基础镜像是远远不能够满足我们的需要,我们就要创建属于自己或者是按照自己的需要对相应的基础镜像进行重新创建。

docker提供两种的创建镜像的方法:
1.使用docker commit对已存在的容器进行重新打包成镜像;
2.就是使用自己编写的Dockerfile来创建自己需要的docker镜像;

本节主要是介绍怎么使用docker commit对已启动和配置好环境变量的容器进行重新打包成无需再次配置的镜像。

docker commit 命令是创建新镜像最直观的方法,其过程包含三个步骤:

  1. 运行容器
  2. 修改容器中需要更新的环境变量
  3. 将容器保存为新的镜像

我们使用docker ps查看当前正在运行的容器
在这里插入图片描述
执行 docker commit 命令将容器保存为镜像。
在这里插入图片描述
其中pedantic_swartz为正在运行的容器名称,newimage为你需要创建的镜像名称。

这时候我们使用docker images命令就可以看到我们刚重新打包创建的新镜像了。
在这里插入图片描述
关于镜像创建的第一种方法大家学会了吗,下节我会继续讲怎么使用Dockerfile创建镜像。

大家有问题或者想和我交流的么也可以关注我的微信公众号:Hugo技术。

sudo journalctl -u docker.service --since today --no-pager -- Logs begin at Tue 2025-07-29 10:32:50 CST, end at Tue 2025-07-29 10:41:30 CST. -- Jul 29 10:38:09 localhost.localdomain systemd[1]: Starting Docker Application Container Engine... Jul 29 10:38:09 localhost.localdomain dockerd[2154]: time="2025-07-29T10:38:09.604082027+08:00" level=info msg="Starting up" Jul 29 10:38:09 localhost.localdomain dockerd[2154]: time="2025-07-29T10:38:09.706394902+08:00" level=info msg="Loading containers: start." Jul 29 10:38:10 localhost.localdomain dockerd[2154]: time="2025-07-29T10:38:10.126878694+08:00" level=info msg="Firewalld: interface docker0 already part of docker zone, returning" Jul 29 10:38:10 localhost.localdomain dockerd[2154]: time="2025-07-29T10:38:10.174422027+08:00" level=info msg="Loading containers: done." Jul 29 10:38:10 localhost.localdomain dockerd[2154]: time="2025-07-29T10:38:10.185075777+08:00" level=warning msg="WARNING: bridge-nf-call-iptables is disabled" Jul 29 10:38:10 localhost.localdomain dockerd[2154]: time="2025-07-29T10:38:10.185092360+08:00" level=warning msg="WARNING: bridge-nf-call-ip6tables is disabled" Jul 29 10:38:10 localhost.localdomain dockerd[2154]: time="2025-07-29T10:38:10.185106569+08:00" level=info msg="Docker daemon" commit=de5c9cf containerd-snapshotter=false storage-driver=overlay2 version=26.1.4 Jul 29 10:38:10 localhost.localdomain dockerd[2154]: time="2025-07-29T10:38:10.185153444+08:00" level=info msg="Daemon has completed initialization" Jul 29 10:38:10 localhost.localdomain dockerd[2154]: time="2025-07-29T10:38:10.199929527+08:00" level=info msg="API listen on /run/docker.sock" Jul 29 10:38:10 localhost.localdomain systemd[1]: Started Docker Application Container Engine. Jul 29 10:39:23 localhost.localdomain systemd[1]: Stopping Docker Application Container Engine... Jul 29 10:39:23 localhost.localdomain dockerd[2154]: time="2025-07-29T10:39:23.341980270+08:00" level=info msg="Processing signal &#39;terminated&#39;" Jul 29 10:39:23 localhost.localdomain dockerd[2154]: time="2025-07-29T10:39:23.385825812+08:00" level=info msg="stopping event stream following graceful shutdown" error="<nil>" module=libcontainerd namespace=moby Jul 29 10:39:23 localhost.localdomain dockerd[2154]: time="2025-07-29T10:39:23.389943395+08:00" level=info msg="Daemon shutdown complete" Jul 29 10:39:23 localhost.localdomain systemd[1]: Stopped Docker Application Container Engine. Jul 29 10:39:23 localhost.localdomain systemd[1]: Starting Docker Application Container Engine... Jul 29 10:39:23 localhost.localdomain dockerd[2348]: unable to configure the Docker daemon with file /etc/docker/daemon.json: invalid character &#39;"&#39; after object key:value pair Jul 29 10:39:23 localhost.localdomain systemd[1]: docker.service: main process exited, code=exited, status=1/FAILURE Jul 29 10:39:23 localhost.localdomain systemd[1]: Failed to start Docker Application Container Engine. Jul 29 10:39:23 localhost.localdomain systemd[1]: Unit docker.service entered failed state. Jul 29 10:39:23 localhost.localdomain systemd[1]: docker.service failed. Jul 29 10:39:25 localhost.localdomain systemd[1]: docker.service holdoff time over, scheduling restart. Jul 29 10:39:25 localhost.localdomain systemd[1]: Stopped Docker Application Container Engine. Jul 29 10:39:25 localhost.localdomain systemd[1]: Starting Docker Application Container Engine... Jul 29 10:39:25 localhost.localdomain dockerd[2355]: unable to configure the Docker daemon with file /etc/docker/daemon.json: invalid character &#39;"&#39; after object key:value pair Jul 29 10:39:25 localhost.localdomain systemd[1]: docker.service: main process exited, code=exited, status=1/FAILURE Jul 29 10:39:25 localhost.localdomain systemd[1]: Failed to start Docker Application Container Engine. Jul 29 10:39:25 localhost.localdomain systemd[1]: Unit docker.service entered failed state. Jul 29 10:39:25 localhost.localdomain systemd[1]: docker.service failed. Jul 29 10:39:28 localhost.localdomain systemd[1]: docker.service holdoff time over, scheduling restart. Jul 29 10:39:28 localhost.localdomain systemd[1]: Stopped Docker Application Container Engine. Jul 29 10:39:28 localhost.localdomain systemd[1]: Starting Docker Application Container Engine... Jul 29 10:39:28 localhost.localdomain dockerd[2362]: unable to configure the Docker daemon with file /etc/docker/daemon.json: invalid character &#39;"&#39; after object key:value pair Jul 29 10:39:28 localhost.localdomain systemd[1]: docker.service: main process exited, code=exited, status=1/FAILURE Jul 29 10:39:28 localhost.localdomain systemd[1]: Failed to start Docker Application Container Engine. Jul 29 10:39:28 localhost.localdomain systemd[1]: Unit docker.service entered failed state. Jul 29 10:39:28 localhost.localdomain systemd[1]: docker.service failed. Jul 29 10:39:30 localhost.localdomain systemd[1]: docker.service holdoff time over, scheduling restart. Jul 29 10:39:30 localhost.localdomain systemd[1]: Stopped Docker Application Container Engine. Jul 29 10:39:30 localhost.localdomain systemd[1]: start request repeated too quickly for docker.service Jul 29 10:39:30 localhost.localdomain systemd[1]: Failed to start Docker Application Container Engine. Jul 29 10:39:30 localhost.localdomain systemd[1]: Unit docker.service entered failed state. Jul 29 10:39:30 localhost.localdomain systemd[1]: docker.service failed.
08-01
<think>根据用户的问题和引用的资料,用户遇到的错误是: "Docker service failed to start unable to configure daemon with file /etc/docker/daemon.json invalid character &#39;\"&#39; after object key:value pair" 这个错误表明`/etc/docker/daemon.json`配置文件存在语法错误,具体是“在对象键值对后出现了无效的字符&#39;"&#39;”。这通常是由于JSON格式不正确导致的。 结合引用[1]、[2]、[3]的内容,我们可以总结出以下常见原因: 1. **JSON语法错误**:如多余的逗号、注释(JSON不支持注释)、引号不匹配、括号不匹配等[^3]。 2. **配置冲突**:在`daemon.json`和`docker.service`文件中同时配置了相同的选项(如`insecure-registries`),导致冲突[^1][^2]。 3. **空格或隐藏字符**:配置文件中有多余的空格或不可见的特殊字符[^3]。 ### 解决步骤: #### 1️⃣ 检查并修复`daemon.json`语法 ```bash # 使用JSON验证工具检查语法 sudo cat /etc/docker/daemon.json | jq . ``` 如果提示`parse error`,则说明文件有语法错误。 **手动修复指南**: - 删除所有注释(JSON标准不支持注释) - 检查逗号:最后一个键值对后面不能有逗号 - 检查引号:确保所有字符串都用双引号,且引号成对出现 - 检查大括号:确保`{}`成对出现 **示例修正**: 错误配置(键`registry-mirrors`后的逗号多余): ```json { "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"], // 这里逗号多余且含注释 "insecure-registries": ["192.168.1.100:5000"] } ``` 修正后: ```json { "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"], "insecure-registries": ["192.168.1.100:5000"] } ``` #### 2️⃣ 检查与`docker.service`的配置冲突 如果错误涉及`insecure-registries`等参数冲突(如引用[2]): ```bash # 查看docker.service的启动参数 sudo systemctl show docker | grep ExecStart ``` 若输出包含`--insecure-registry`等参数,则需: - **方案A**:删除`docker.service`中的参数(推荐) ```bash sudo vim /usr/lib/systemd/system/docker.service # 删除ExecStart行中的--insecure-registry等参数 sudo systemctl daemon-reload ``` - **方案B**:删除`daemon.json`中的对应配置(二选一) #### 3️⃣ 重新加载并重启 ```bash sudo systemctl daemon-reload sudo systemctl restart docker ``` #### 4️⃣ 验证服务状态 ```bash sudo systemctl status docker journalctl -xe -u docker --since "5 minutes ago" ``` ### 特殊情况处理 若修复后仍报错,考虑: - **文件编码问题**:确保为UTF-8无BOM ```bash sudo iconv -f utf-8 -t utf-8 /etc/docker/daemon.json -o /etc/docker/daemon.json.clean sudo mv /etc/docker/daemon.json.clean /etc/docker/daemon.json ``` - **彻底重置配置**(慎用): ```bash echo &#39;{}&#39; | sudo tee /etc/docker/daemon.json # 重置为空配置 ``` ### 相关问题 1. 如何验证JSON文件的语法正确性? 2. Docker的`daemon.json`和`docker.service`配置优先级如何? 3. 如何解决`insecure-registries`配置冲突? 4. 为什么JSON文件不支持注释?如何绕过? 5. Docker启动失败还有哪些常见原因? > **关键提示**:本案例中错误明确指向JSON语法,优先修复引号不匹配问题[^3]。若需进一步帮助,请提供`sudo cat /etc/docker/daemon.json`的输出(注意脱敏敏感信息)。</think>### 🔍 解决 Docker 启动失败:`unable to configure daemon with file /etc/docker/daemon.json` 错误 根据您提供的错误信息 `invalid character &#39;"&#39; after object key:value pair`,结合引用内容[1][2][3],问题核心是 **`/etc/docker/daemon.json` 配置文件存在语法错误**。以下是详细解决方案: --- ### 🛠 分步解决指南 #### 1️⃣ 检查并修复 JSON 语法错误(关键步骤) ```bash # 查看配置文件内容 sudo cat /etc/docker/daemon.json ``` **常见错误类型及修复方案:** | **错误类型** | **修复方法** | **示例对比** | |-----------------------|-----------------------------------------------------------------------------|-------------| | **多余的逗号** | 删除最后一个键值对后的逗号 | `"key": "value",` ❌ → `"key": "value"` ✅ | | **注释未删除** | 删除所有 `//` 或 `/* */` 注释(JSON 标准不支持注释)[^3] | `// 镜像设置` ❌ → 删除整行 ✅ | | **引号不匹配** | 确保所有字符串值用双引号包裹,且引号成对出现 | `registry: "https://...` ❌ → `"registry": "https://..."` ✅ | | **括号不匹配** | 检查 `{ }` 和 `[ ]` 是否成对出现 | `{ "key": [ "a", "b" }` ❌ → `{ "key": [ "a", "b" ] }` ✅ | | **多余的空格/特殊字符** | 删除行尾空格和不可见字符 | 使用 `:set list` 在 vim 中显示隐藏字符 | #### 2️⃣ 处理配置冲突(如引用[1][2]) 如果同时存在以下配置冲突: - `/etc/docker/daemon.json` 中的 `insecure-registries` - `/usr/lib/systemd/system/docker.service` 中的 `--insecure-registry` 参数 **解决方案:** ```bash # 打开 docker.service 文件 sudo vim /usr/lib/systemd/system/docker.service # 在 ExecStart 行中删除 --insecure-registry 参数 # 修改前:ExecStart=/usr/bin/dockerd --insecure-registry=192.168.1.10 # 修改后:ExecStart=/usr/bin/dockerd ``` #### 3️⃣ 验证并重载配置 ```bash # 检查 JSON 语法(安装 jq 工具) sudo apt install jq # Ubuntu/Debian sudo yum install jq # CentOS/RHEL # 验证语法 sudo cat /etc/docker/daemon.json | jq empty # 重载配置并重启 sudo systemctl daemon-reload sudo systemctl restart docker ``` #### 4️⃣ 最小化配置测试 如果仍失败,尝试最小配置: ```bash # 创建最小配置 echo &#39;{}&#39; | sudo tee /etc/docker/daemon.json # 重启服务 sudo systemctl restart docker ``` 若成功,逐步添加配置项排查问题项。 --- ### ⚠️ 配置文件示例(正确格式) ```json { "insecure-registries": ["192.168.1.100:5000"], "registry-mirrors": ["https://docker.mirrors.ustc.edu.cn"], "debug": true } ``` **注意:** - 最后一个键值对 **不能有逗号** - 所有字符串必须用 **双引号** - **不能有注释**(删除所有 `//` 或 `#` 开头的行) --- ### 📌 相关命令解析 ```bash # 查看完整错误日志(推荐) sudo journalctl -u docker.service -n 50 --no-pager # 检查服务状态 sudo systemctl status docker # 清理缓存配置 sudo systemctl daemon-reload ``` --- ### ✅ 验证成功 ```bash # 检查服务状态 sudo systemctl status docker # 测试容器运行 sudo docker run hello-world ``` --- ### 📚 相关问题 1. 如何正确配置 Docker 的 `insecure-registries`? 2. `daemon.json` 和 `docker.service` 的配置优先级哪个更高? 3. 如何排查 JSON 配置文件中的隐藏字符错误? 4. Docker 服务启动失败还有哪些常见原因? 5. 如何永久修改 Docker 的守护进程参数? > **关键提示**:90% 的此类错误是由于 JSON 语法问题引起[^3],请优先检查逗号、引号和括号的匹配。若问题仍存在,请提供 `sudo cat /etc/docker/daemon.json` 的输出(脱敏敏感信息)。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

Hugo_Hoo

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值