如有错误,恳请指出。


华为比赛终于告一段落,最后是常见的直接提交整个的docker环境

在这里插入图片描述

在之前的文章中也简要介绍过Docker的大概使用方法Docker | 使用docker配置深度学习pytorch环境。不过在重新的配置过程中,出现了部分错误,用这篇文章来主要记录一下错误的解决过程,顺便再记录下如何使用docker对镜像进行打包和保存。

1. Docker镜像打包

1.1 容器保存为镜像

作用:在现在容器镜像上保存镜像进行打包,在另一台服务上使用;或现有的容器安装了一些库,配置了开发环境,需要保存下载,下次加载后直接使用。

  • 首先查看下现有容器镜像(目的是查询需要保存镜像的ID)
docker ps -a
  • 接下来用commit参数进行保存镜像(精简版)
docker commit  7ca736d99653    yolov5:v6.2

其中,7ca736d99653 是需要保存镜像的ID,刚才用docker ps -a 查询到的。

yolov5:v6.2 是需要保存镜像的REPOSITORY、和TAG,这两个自由设定的。(yolov5 对应REPOSITORY、v6.2对应TAG;两者用:分割开。)

(详细版)或者用commit参数进行保存镜像, -a 提交人的姓名 -m “提交内容”,格式如:docker commit -a -m 现有容器ID 保存后的名称:版本号

docker commit -a "xiaoming"   -m "Update target detection model" 7ca736d99653    yolov5:v6.2
  • 查看镜像是否保存成功
docker images

1.2 将镜像打包

使用save参数进行打包,格式如:docker save -o tar文件名称 镜像REPOSITORY:TAG

docker save -o yolov5-v6.2.tar yolov5:v6.2

其中yolov5:v6.2 是需要保存镜像的REPOSITORY、和TAG;也是上面保存的镜像名称


1.3 将镜像加载

使用load进行从tar文件导出镜像

docker load -i yolov5-v6.2.tar

然后查看是否出现镜像

docker  images

2. Docker错误集合

问题1: job for docker.service failed

报错的代码:service docker start

问题描述:在重新安装了docker之后,想要开启docker服务,随后出现了报错,错误信息如下所示:

job for docker.service failed because the control process exited with
error code. See “systemctl status docker.service” and “journalctl -xe”
for details

试错流程如下所示:

  • 尝试1:更新yum包,重装docker

卸载docker环境包
查询安装过的包
yum list installed | grep docker

删除安装的软件包
yum -y remove docker.x86_64
yum -y remove docker-client.x86_64
yum -y remove docker-common.x86_64

然后进行重新安装docker的过程

1.查看内核版本 <Docker 要求 CentOS 系统的内核版本高于 3.10>
uname -r
2.把yum包更新到最新
sudo yum update
3.安装需要的软件包, yum-util 提供yum-config-manager功能,另外两个是devicemapper驱动依赖的
sudo yum install -y yum-utils device-mapper-persistent-data lvm2
4.设置yum源
sudo yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo
5.查看仓库中docker版本
yum list docker-ce --showduplicates | sort -r
6. 安装docker
sudo yum install docker-ce
7.启动Docker,设置开机启动,停止Docker
sudo systemctl start docker
sudo systemctl enable docker
sudo systemctl stop docker
8.查看版本
docker version
9.使用一下确认是否启动成功,使用search 查一下
docker search mysql
10.查看日志状态成功日志
systemctl status docker.service

参考资料:Docker服务启动报错:Job for docker.service failed because the control process exited with error

  • 尝试2:将/etc/sysconfig/selinux的 selinux 属性值改为disabled

使用docker version命令,查看docker版本,只有client,没有server

解决方法是执行 vi /etc/sysconfig/selinux , 把 selinux 属性值改为disabled。然后重启系统

在这里插入图片描述

参考资料:CentOS7安装docker 启动失败:Job for docker.service failed… 解决办法

  • 尝试3:配置daemon.json文件

create daemon.json in /etc/docker/添加以下内容:

{
"exec-root": "/path/to/docker/run",
"storage-driver": "overlay",
"graph": "/path/to/docker/lib"
}

参考资料:docker 报错 Job for docker.service failed because the control process exited with error code. See "…

  • 尝试4:重新配置daemon.json文件

直接 vi /etc/docker/daemon.json,添加以下内容:

{ "storage-driver": "devicemapper" }

然后重启一下docker,执行service docker start,即可成功。

参考资料:Docker 实战笔记

最后,在尝试4中成功解决了问题,docker服务可以正常的开启,随后查看docker version,可以发现同时存在client和server。

在这里插入图片描述


问题2:Error response from daemon: Get “https://registry-1.docker.io/v2/”

报错代码:docker pull python:3.9.14

问题描述:这里想拉取一个python3.9的镜像使用,随后在https://hub.docker.com/中寻找了一个,执行 docker pull python:3.9.14 进行的报错,也就是无法进行docker pull指令。

在这里插入图片描述
详细报错如下:

Error response from daemon: Get “https://registry-1.docker.io/v2/”:
x509: certificate is valid for *.blackboard.com, not
registry-1.docker.io

试错流程如下所示:

  • 尝试1:证书过期

可能是原来是因为本地系统时间错误导致报错证书过期,输入下面语句同步一下时间

ntpdate cn.pool.ntp.org 

参考资料:docker报错Get https://registry-1.docker.io/v2/: x509: certificate has expired or is not yet valid

  • 尝试2:尝试修改/etc/hosts强制docker.io相关的域名解析到其它可用IP

第一步:通过dig @114.114.114.114 registry-1.docker.io找到可用IP

在这里插入图片描述

第二步:尝试修改/etc/hosts强制docker.io相关的域名解析到其它可用IP,直接vim /etc/hosts添加一个可用IP,这里我添加了两个可用IP(107.23.149.57这个IP其实可以删掉的)

在这里插入图片描述

参考资料:docker pull 报错解决办法

配置完之后,需要重新开启docker服务:service docker start ,随后即可正常的docker pull拉取镜像使用。


参考资料:

1. docker保存镜像、打包tar、加载tar镜像

2. Docker 实战笔记

3. docker pull 报错解决办法

Logo

权威|前沿|技术|干货|国内首个API全生命周期开发者社区

更多推荐