Docker | docker容器导出以及常见问题的处理

本文涉及的产品
容器镜像服务 ACR,镜像仓库100个 不限时长
简介: Docker | 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.查看内核版本

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。然后重启系统

image.png

参考资料: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。

image.png


问题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指令。

image.png

详细报错如下:

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

image.png

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

image.png

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

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


参考资料:

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

2. Docker 实战笔记

3. docker pull 报错解决办法

目录
相关文章
|
17天前
|
监控 NoSQL 时序数据库
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
《docker高级篇(大厂进阶):7.Docker容器监控之CAdvisor+InfluxDB+Granfana》包括:原生命令、是什么、compose容器编排,一套带走
157 77
|
25天前
|
监控 Docker 容器
在Docker容器中运行打包好的应用程序
在Docker容器中运行打包好的应用程序
|
4天前
|
存储 Kubernetes 开发者
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
Docker 是一种开源的应用容器引擎,允许开发者将应用程序及其依赖打包成可移植的镜像,并在任何支持 Docker 的平台上运行。其核心概念包括镜像、容器和仓库。镜像是只读的文件系统,容器是镜像的运行实例,仓库用于存储和分发镜像。Kubernetes(k8s)则是容器集群管理系统,提供自动化部署、扩展和维护等功能,支持服务发现、负载均衡、自动伸缩等特性。两者结合使用,可以实现高效的容器化应用管理和运维。Docker 主要用于单主机上的容器管理,而 Kubernetes 则专注于跨多主机的容器编排与调度。尽管 k8s 逐渐减少了对 Docker 作为容器运行时的支持,但 Doc
31 5
容器化时代的领航者:Docker 和 Kubernetes 云原生时代的黄金搭档
|
9天前
|
关系型数据库 应用服务中间件 PHP
实战~如何组织一个多容器项目docker-compose
本文介绍了如何使用Docker搭建Nginx、PHP和MySQL的环境。首先启动Nginx容器并查看IP地址,接着启动Alpine容器并安装curl测试连通性。通过`--link`方式或`docker-compose`配置文件实现服务间的通信。最后展示了Nginx配置文件和PHP代码示例,验证了各服务的正常运行。
30 3
实战~如何组织一个多容器项目docker-compose
|
4天前
|
Unix Linux Docker
CentOS停更沉寂,RHEL巨变限制源代:Docker容器化技术的兴起助力操作系统新格局
操作系统是计算机系统的核心软件,管理和控制硬件与软件资源,为用户和应用程序提供高效、安全的运行环境。Linux作为开源、跨平台的操作系统,具有高度可定制性、稳定性和安全性,广泛应用于服务器、云计算、物联网等领域。其发展得益于庞大的社区支持,多种发行版如Ubuntu、Debian、Fedora等满足不同需求。
18 4
|
19天前
|
数据建模 应用服务中间件 nginx
docker替换宿主与容器的映射端口和文件路径
通过正确配置 Docker 的端口和文件路径映射,可以有效地管理容器化应用程序,确保其高效运行和数据持久性。在生产环境中,动态替换映射配置有助于灵活应对各种需求变化。以上方法和步骤提供了一种可靠且易于操作的方案,帮助您轻松管理 Docker 容器的端口和路径映射。
60 3
|
25天前
|
负载均衡 网络协议 算法
Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式
本文探讨了Docker容器环境中服务发现与负载均衡的技术与方法,涵盖环境变量、DNS、集中式服务发现系统等方式,以及软件负载均衡器、云服务负载均衡、容器编排工具等实现手段,强调两者结合的重要性及面临挑战的应对措施。
59 3
|
25天前
|
存储 安全 数据安全/隐私保护
Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。
在数字化时代,Docker 容器化应用管理更加高效,但数据安全和业务连续性成为关键。本文探讨了 Docker 应用的备份与恢复策略,涵盖备份的重要性、内容、方法及常见工具,制定备份策略,恢复流程及注意事项,并通过案例分析和未来趋势展望,强调备份与恢复在保障应用安全中的重要性。
31 2
|
25天前
|
存储 安全 数据中心
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具
Docker 容器凭借轻量级和高效的特性,成为应用部署的重要工具。本文探讨了 Docker 如何通过 Namespace 和 Cgroups 实现 CPU、内存、网络和存储资源的隔离,提高系统安全性和资源利用率,以及面临的挑战和应对策略。
43 1