百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

【Docker 新手入门指南】第十五章:常见故障排除

ztj100 2025-07-21 19:11 5 浏览 0 评论

一、前期准备:收集关键信息

在排查问题前,建议先获取以下系统数据,便于精准定位故障:

1. 系统基础信息

# 查看 Docker 版本(确认是否为最新稳定版)
docker version  

# 查看 Docker 系统配置(存储驱动、Cgroup 版本等)
docker info  

# 查看 Docker 守护进程日志(定位守护进程启动异常)
journalctl -u docker.service -xe

2. 容器运行状态

# 列出所有容器(包括停止状态)
docker ps -a  

# 查看容器实时日志(添加 --follow 追踪最新日志)
docker logs [容器ID/名称]  

# 获取容器详细配置(网络、挂载、资源限制等)
docker inspect [容器ID/名称]

二、常见问题分类排查

1. 安装与初始化问题
典型症状:权限错误、守护进程启动失败、服务无法初始化

  • 权限不足
# 将当前用户加入 docker 用户组(需重启终端生效) 
sudo usermod -aG docker $USER newgrp docker # 立即生效权限变更
  • 守护进程状态异常
# 检查服务状态(active/running 为正常)

sudo systemctl status docker # 重启/启动服务 
sudo systemctl restart docker sudo systemctl enable --now docker # 开机自启并立即启动
  • 依赖缺失(Linux 系统)
    • Ubuntu/Debian:确保安装 apt-transport-httpsca-certificatescurl 等依赖
    • CentOS:安装 yum-utils 并配置稳定仓库源

2. 网络连接问题
典型症状:容器无法联网、端口映射失效、跨容器通信失败

  • 网络配置检查
# 查看默认网络(bridge 为默认网络) 
docker network ls 

# 检查容器所属网络配置(IP、DNS、网关) 
docker network inspect bridge
  • 端口冲突
# 查看宿主机端口占用(替换 <端口号>)
sudo lsof -i :<端口号> 
  
  # 更换映射端口(例如将容器 80 端口映射到宿主机 8080)
  docker run -p 8080:80 nginx
  • DNS 解析失败
    • 修改 Docker 守护进程配置(/etc/docker/daemon.json):
{ 
  "dns": ["8.8.8.8", "8.8.4.4"] # 配置公共 DNS 服务器 
}
    • 重启 Docker 服务使配置生效

3. 存储与磁盘问题
典型症状:磁盘空间不足、数据卷挂载失败、镜像无法删除

  • 清理无效资源
# 清理所有停止的容器、未使用的镜像和网络
docker system prune -a -f  

# 查看磁盘占用详情(镜像/容器/数据卷分布)
docker system df  
  • 数据卷异常
# 列出所有数据卷
docker volume ls  

# 检查数据卷挂载路径(宿主机路径是否存在)
docker volume inspect [卷名]  
  • 镜像残留清理
# 删除悬空镜像(无标签的临时镜像)
docker image prune -f  

# 强制删除镜像(包含依赖标签)
docker rmi -f [镜像ID]  

4. 性能与资源问题
典型症状:容器卡顿、CPU/内存占用过高、宿主机性能下降

  • 资源监控
# 实时监控容器资源(CPU/内存/网络/IO)
docker stats [容器ID/名称]  

# 查看容器内进程(排查异常进程)
docker top [容器ID/名称]  
  • 资源限制配置
# 限制 CPU(0.5 核)和内存(512MB)
docker run -d --cpus="0.5" --memory=512m nginx  

# 限制磁盘 IO(示例:读写速率 10MB/s)
docker run -d --device-read-bps=/dev/sda:10mb --device-write-bps=/dev/sda:10mb myapp  

5. 镜像构建与拉取问题
典型症状:镜像拉取超时、构建失败、镜像标签错误

  • 仓库连接问题
# 登录私有仓库(检查账号密码是否正确)
docker login [仓库地址]  

# 使用镜像加速器(国内推荐腾讯云/阿里云镜像)
sudo nano /etc/docker/daemon.json  
{
  "registry-mirrors": ["https://mirror.ccs.tencentyun.com"]
}
  • Dockerfile 构建错误
    • 检查构建上下文路径(避免包含无关文件)
    • 添加 --no-cache 跳过缓存重新构建:
docker build --no-cache -t myapp .  
    • 通过 docker build --progress=plain 查看详细构建日志

6. 安全与权限问题
典型症状:容器以 root 运行、镜像存在漏洞、访问控制失效

  • 非 root 用户运行容器
# 指定 UID/GID 运行(需镜像支持非 root 用户)
docker run -d --user 1001:1001 nginx  
  • 漏洞扫描与修复
# 使用 Docker Scan 扫描镜像漏洞(需先安装 Trivy)
docker scan [镜像名]:[标签]  

# 查看镜像敏感配置(如特权模式)
docker inspect --format='{{.HostConfig.Privileged}}' [镜像ID]  

三、常见错误代码与解决方案

错误信息

可能原因

解决方法

Error response from daemon: conflict

容器名称冲突

docker rm [冲突容器名] 或指定新名称

port is already allocated

端口被占用

更换端口或终止占用进程

OCI runtime create failed

内核参数不支持

检查 Cgroup 驱动(docker info 确认)

manifest unknown

镜像不存在或标签错误

确认镜像名/标签是否正确,重新拉取

driver failed programming external connectivity

防火墙或网络配置错误

关闭防火墙或配置 iptables 规则

四、最佳实践与维护建议

预防措施

  1. 定期备份:对重要数据卷和 docker-compose.yml 进行版本控制
  2. 资源隔离:使用 docker-compose 管理多容器应用,配置 cpu_shares/memory 限制
  3. 版本管理:固定镜像标签(如 nginx:1.23-alpine),避免使用 latest 标签

日常维护

# 每周清理无效资源
docker system prune -a -f --volumes  

# 每月更新 Docker 和镜像
sudo apt update && sudo apt upgrade docker-ce  
docker pull --all-tags nginx  # 强制更新所有标签镜像

日志管理

  • 配置日志驱动(如 json-file 或接入 ELK 系统):
{
  "log-driver": "json-file",
  "log-opts": {
    "max-size": "10m",
    "max-file": "3"
  }
}

相关推荐

新手学Docker:挂载卷Volumes(docker挂载nfs卷)

默认情况下,在容器内创建的文件,都会保存在容器基于镜像之上的一个可读写层。但是,这一层是依赖于容器而存在的,当容器不存在时,这些数据也就不存在了。而且这些数据紧紧的耦合在容器内部,很难将这些数据导出。...

Docker命令最全详解(39个最常用命令)

Docker是云原生的核心,也是大厂的必备技能,下面我就全面来详解Docker核心命令@mikechen本文作者:陈睿|mikechen文章来源:mikechen.cc一、Docker基本命令...

松勤软件测试:详解Docker,如何用portainer管理Docker容器

镜像管理搜索镜像dockersearch镜像名称拉取镜像dockerpullname[:tag]列出镜像dockerimages删除镜像dockerrmiimage名称或id删除...

【Docker 新手入门指南】第十四章:Docker常用命令

以下Docker常用命令大全,涵盖容器、镜像、网络、数据卷及系统管理等核心操作,结合分类与示例助你快速掌握:一、容器生命周期管理...

Docker 一键清盘术,释放磁盘空间不求人

在日常开发和运维中,Docker容器化让我们的工作更高效,但不知不觉中,磁盘空间却被镜像、容器和卷悄悄吃掉。今天教你一套干净利落的Docker磁盘清理攻略,让你轻松腾出宝贵空间!一、快速查看磁盘...

第六节 Docker 容器核心操作与实践指南

一、镜像与容器的本质关系(一)镜像(Image)的核心特性静态模板:包含应用运行所需的所有依赖(系统库、运行时、配置文件等)不可变性:镜像构建完成后内容不可修改,确保环境一致性...

别再去找Docker命令了,你要的常用的全都在这

Docker常用命令集合给大家介绍一些常用的Docker命令,对你有帮助的同学建议收藏作为一个查询手册哦。Docker容器的一些命令按功能分类大致如下:Docker环境信息info、versio...

Docker 数据持久化最佳实践:Volume 使用全指南

你是不是也经常在使用Docker的时候,遇到“数据持久化”相关的困惑?容器删了,数据也跟着没了?今天就带你深入了解Docker的Volume机制,搞懂什么是Volume、怎么使用、存储在...

【Docker 新手入门指南】第十五章:常见故障排除

一、前期准备:收集关键信息在排查问题前,建议先获取以下系统数据,便于精准定位故障:...

Docker网络与iptables实战指南:从原理到安全加固

一、Docker网络核心原理:容器与iptables的“共生关系”Docker容器的网络能力依赖于Linux内核的两大核心技术:虚拟网络设备(vethpair、网桥)和iptables规则链。以默认...

别再docker exec了!盘点进入容器排错的5种“更优雅”姿势

一、dockerattach:直接“附身”容器的原始方法当容器日志疯狂刷屏时,dockerattach就像直接跳进正在行驶的汽车——能看到仪表盘数据,但方向盘不在你手上。这种直接附加到容器主进程的...

云计算核心技术Docker教程:Docker数据卷的使用

在生产环境中使用Docker,要想实现数据的持久化(所谓Docker的数据持久化即数据不随着Container的结束而结束)或者需要在多个容器之间进行数据共享,需要将数据从宿主机挂载到容器中,这就会...

【开发技术】Mybatis中进行多表关联查询?性能是不是会变好呢?

Mybatis是一种基于Java的持久层框架,能够帮助我们操作数据库。在Mybatis中,进行多表关联的整合查询,需要使用嵌套查询或者使用ResultMap进行映射。下面,我们将从这两个方面来介绍多表...

Mybatis 批量更新数据 Mysql批量更新数据

通常如果需要一次更新多条数据有两个方式,(1)在业务代码中循环遍历逐条更新。(2)一次性更新所有数据1批量更新相同的值不同的条件...

Mybatis 如何批量删除数据(mybatis批量merge)

Mybatis如何批量删除数据本期以最常用的根据id批量删除数据为例:接口设计1:List类型单参数IntegerdeleteByIds(List<Integer>ids);...

取消回复欢迎 发表评论: