WisdomSSH解决docker run命令中log-opt参数不支持导致的容器创建失败问题

在使用 docker run 命令部署一个名为 autman 的应用时,我遇到了容器无法正常启动的问题。起初,我尝试执行如下命令:

bash 复制代码
docker run -d --name autman --restart always -p 8080:8080 -p 8081:8081 -v /root/autman:/autMan --log-opt max-size=10m --log-opt max-file=3 docker.1ms.run/hdbjlizhe/autman:latest

然而,执行后返回了错误信息:

复制代码
docker: Error response from daemon: unknown log opt 'max-file' for journald log driver

这表明当前 Docker 环境所使用的日志驱动(journald)并不支持 max-file 这个选项。随后,我尝试移除该参数,但新的错误随之出现:

复制代码
docker: Error response from daemon: unknown log opt 'max-size' for journald log driver

此时,我意识到 --log-opt 参数可能与当前系统日志驱动不兼容。由于 journald 是 systemd 管理的默认日志驱动,其本身不支持 max-sizemax-file 这类基于文件大小和数量的日志轮转控制。

为了确认这一判断,我检查了系统日志驱动配置。通过运行 docker info | grep -i logging 可以发现,日志驱动确实为 journald,因此 --log-opt 中指定的参数无法生效。

在排除了日志选项的干扰后,我继续排查其他潜在问题。再次执行相同命令时,出现了新的报错:

复制代码
docker: Error response from daemon: Conflict. The container name "/autman" is already in use by container "fab740542af72c0071a9d57af193e50ac23e104af8518901028c2157546c46d6". You have to remove (or rename) that container to be able to reuse that name.

该错误明确指出,容器名称 autman 已被占用。这说明此前已存在一个同名容器,尽管它可能处于停止状态,但 Docker 仍不允许重复命名。

为解决此冲突,我采取以下步骤:

  1. 使用 docker stop autman 命令停止正在运行的旧容器;
  2. 使用 docker rm autman 命令删除已存在的容器实例;
  3. 最后重新执行创建命令。

完整执行流程如下:

bash 复制代码
docker stop autman && docker rm autman && docker run -d --name autman --restart always -p 8080:8080 -p 8081:8081 -v /root/autman:/autMan docker.1ms.run/hdbjlizhe/autman:latest

命令成功执行,输出显示新容器已创建并启动,返回容器唯一标识符:892affb0a8750b2ddb712c98d350f27daa8522d3c8b883340e6238b79244a081

最终,我确认容器已正常运行。通过以下命令验证:

bash 复制代码
docker ps -a | grep autman

输出包含 Up 状态,且 PORTS 显示 8080 和 8081 端口已映射,表明服务已就绪。

综上所述,本次问题的根本原因在于:

  • 当前环境的 journald 日志驱动不支持 --log-opt max-size--log-opt max-file
  • 容器名称 autman 被先前创建的容器占用,导致命名冲突。

解决方案是:移除不兼容的日志选项,并清除同名容器后重试。整个过程通过逐步排查、定位、修复,最终实现容器成功部署。

相关推荐
java_logo10 小时前
OpenProject Docker 容器化部署指南:从快速启动到生产环境配置
docker·容器·openproject·openproject部署·openproject部署手册·openproject部署方案·openproject部署教程
毕设源码-朱学姐10 小时前
【开题答辩全过程】以 基于JavaWeb的网上家具商城设计与实现为例,包含答辩的问题和答案
java
曦云沐11 小时前
【避坑指南】Ubuntu更新报错“Repository is not signed”的快速修复
linux·ubuntu·docker
C雨后彩虹12 小时前
CAS与其他并发方案的对比及面试常见问题
java·面试·cas·同步·异步·
java1234_小锋13 小时前
Java高频面试题:SpringBoot为什么要禁止循环依赖?
java·开发语言·面试
2501_9445255413 小时前
Flutter for OpenHarmony 个人理财管理App实战 - 账户详情页面
android·java·开发语言·前端·javascript·flutter
计算机学姐13 小时前
基于SpringBoot的电影点评交流平台【协同过滤推荐算法+数据可视化统计】
java·vue.js·spring boot·spring·信息可视化·echarts·推荐算法
cg_ssh13 小时前
Docker 下启动 Nacos 3.1.1 单机模式
运维·docker·容器
Filotimo_13 小时前
Tomcat的概念
java·tomcat