openEuler安装Docker和踩坑分析

2024-08-29 06:20
文章标签 分析 安装 docker openeuler

本文主要是介绍openEuler安装Docker和踩坑分析,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

 我是用的openEuler版本:20.03 LTS SP1,安装在虚拟机中,使用ssh连接

在openEuler上安装Docker还是让我踩了不少坑,先看看这些坑是如何产生的

虽然官方没有说openEuler是基于什么开源系统开发的,但大致内容和CentOS相似,首先参照官网文档安装步骤如下:

这里插一嘴,旧版本的Docker称为Docker或Docker Engine。17年改为基于YY.MM的版本, Docker Engine改为Docker CE(社区版),Docker Data Center改为Docker EE(企业版)

如果要卸载旧版本查看官方文档:https://docs.docker.com/engine/install/centos/#uninstall-old-versions

安装方法

官方给出了3种安装方法:

  • 从Docker的存储库中安装(https://docs.docker.com/engine/install/centos/#install-using-the-repository)
  • 下载RPM包并手动安装(https://docs.docker.com/engine/install/centos/#install-from-a-package)
  • 使用自动化脚本(https://docs.docker.com/engine/install/centos/#install-using-the-convenience-script)
安装步骤

我使用第一种方法进行安装

  1. 因为需要用到yum-config-manager工具,所以需要安装yum-utils包。之后使用 yum-config-manager 添加docker-ce的软件仓库

    sudo yum install -y yum-utils

    image-20210701221806707

    软件仓库里找不到这个包,那好吧,添加仓库源

    我是用的是华为云开源镜像站的镜像(https://mirrors.huaweicloud.com)

    wget -O /etc/yum.repos.d/openEulerOS.repo https://repo.huaweicloud.com/repository/conf/openeuler_x86_64.repo
    yum clean all
    yum makecache

    然后重新安装yum-utils

    sudo yum install -y yum-utils

    image-20210701222717286

    居然还不行,再次我表示很郁闷,直接被卡在第一步了

    在愤愤不平许久之后,发现系统自带yum-config-manager,顶着好奇的心查看了这个命令路径

    image-20210701224004778

    由于openEuler自带dnf包管理器,它直接建立一个链接指向dnf-utils

    那我们直接执行下面语句,软件源官方较慢,我们使用国内镜像源。

    sudo yum-config-manager \--add-repo \https://repo.huaweicloud.com/docker-ce/linux/centos/docker-ce.repo

    注意的是使用华为镜像源需要执行以下命令替换文件中的部分内容:

    sudo sed -i 's+download.docker.com+repo.huaweicloud.com/docker-ce+' /etc/yum.repos.d/docker-ce.repo

    然后更新建立缓存:

    sudo yum makecache

    image-20210701225704777

    再次出了问题,404,难道是地址不对吗

    image-20210701225849094

    果然,再次分析发现:

    cat /etc/yum.repos.d/docker-ce.repo

    输出内容:

    [docker-ce-stable]
    name=Docker CE Stable - $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/$releasever/$basearch/stable
    enabled=1
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-stable-debuginfo]
    name=Docker CE Stable - Debuginfo $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/$releasever/debug-$basearch/stable
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-stable-source]
    name=Docker CE Stable - Sources
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/$releasever/source/stable
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-test]
    name=Docker CE Test - $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/$releasever/$basearch/test
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-test-debuginfo]
    name=Docker CE Test - Debuginfo $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/$releasever/debug-$basearch/test
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-test-source]
    name=Docker CE Test - Sources
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/$releasever/source/test
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-nightly]
    name=Docker CE Nightly - $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/$releasever/$basearch/nightly
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-nightly-debuginfo]
    name=Docker CE Nightly - Debuginfo $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/$releasever/debug-$basearch/nightly
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-nightly-source]
    name=Docker CE Nightly - Sources
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/$releasever/source/nightly
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg

    其中 $releasever代表当前系统的版本, $basearch代表当前系统的架构

    查看系统信息:

    cat /etc/os-release

    输出:

    NAME="openEuler"
    VERSION="20.03 (LTS-SP1)"
    ID="openEuler"
    VERSION_ID="20.03"
    PRETTY_NAME="openEuler 20.03 (LTS-SP1)"
    ANSI_COLOR="0;31"

    查看系统架构:

    arch

    输出:

    x86_64

    由于使用CentOS中的Docker软件源安装,且https://repo.huaweicloud.com/docker-ce/linux/centos/中没有名为20.03LTS_SP1的版本,我们只好手动更改软件源:

    $releasever替换为7(至于为什么替换为7而不是8,在安装过程中测试8存在部分问题)

    [docker-ce-stable]
    name=Docker CE Stable - $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/$basearch/stable
    enabled=1
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-stable-debuginfo]
    name=Docker CE Stable - Debuginfo $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/debug-$basearch/stable
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-stable-source]
    name=Docker CE Stable - Sources
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/source/stable
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-test]
    name=Docker CE Test - $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/$basearch/test
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-test-debuginfo]
    name=Docker CE Test - Debuginfo $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/debug-$basearch/test
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-test-source]
    name=Docker CE Test - Sources
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/source/test
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-nightly]
    name=Docker CE Nightly - $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/$basearch/nightly
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-nightly-debuginfo]
    name=Docker CE Nightly - Debuginfo $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/debug-$basearch/nightly
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-nightly-source]
    name=Docker CE Nightly - Sources
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/source/nightly
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg

    删掉/etc/yum.repos.d/ 下的docker-ce.repo 文件,使用vi docker-ce.repo建立文件后将上面替换完成的内容粘贴进去保存。

    然后更新建立缓存:

    sudo yum makecache

    在插一嘴,yum-config-manager其实就是一个方便管理软件源的脚本,完全可以手动下载软件源到配置目录。

    wget -O /etc/yum.repos.d/docker-ce.repo https://repo.huaweicloud.com/docker-ce/linux/centos/docker-ce.repo
    sudo sed -i 's+download.docker.com+repo.huaweicloud.com/docker-ce+' /etc/yum.repos.d/docker-ce.repo
    sudo yum makecache
    

    这么也没多写多少字母,其实复制粘贴不就解决问题了。

  2. 安装最新版本的Docker Engine和containerd

    sudo yum install docker-ce docker-ce-cli containerd.io

    image-20210701231630620

    又出问题了,查找软件源中是否存在此包:

    yum search fuse-overlayfs
    yum search slirp4netns

    其结果都是:

    上次元数据过期检查:0:05:30 前,执行于 2021年07月01日 星期四 19时56分15秒。
    未找到匹配项。
    

    没有软件源就添加软件源:

    wget -O /etc/yum.repos.d/CentOS-Base.repo https://repo.huaweicloud.com/repository/conf/CentOS-7-reg.repo

    注意再次将此文件中的$releasever替换为7

    # CentOS-Base.repo
    #
    # The mirror system uses the connecting IP address of the client and the
    # update status of each mirror to pick mirrors that are updated to and
    # geographically close to the client.  You should use this for CentOS updates
    # unless you are manually picking other mirrors.
    #
    # If the mirrorlist= does not work for you, as a fall back you can try the
    # remarked out baseurl= line instead.
    #
    #[base]
    name=CentOS-7 - Base - repo.huaweicloud.com
    baseurl=https://repo.huaweicloud.com/centos/7/os/$basearch/
    #mirrorlist=https://mirrorlist.centos.org/?release=7&arch=$basearch&repo=os
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/centos/RPM-GPG-KEY-CentOS-7#released updates
    [updates]
    name=CentOS-7 - Updates - repo.huaweicloud.com
    baseurl=https://repo.huaweicloud.com/centos/7/updates/$basearch/
    #mirrorlist=https://mirrorlist.centos.org/?release=7&arch=$basearch&repo=updates
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/centos/RPM-GPG-KEY-CentOS-7#additional packages that may be useful
    [extras]
    name=CentOS-7 - Extras - repo.huaweicloud.com
    baseurl=https://repo.huaweicloud.com/centos/7/extras/$basearch/
    #mirrorlist=https://mirrorlist.centos.org/?release=7&arch=$basearch&repo=extras
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/centos/RPM-GPG-KEY-CentOS-7#additional packages that extend functionality of existing packages
    [centosplus]
    name=CentOS-7 - Plus - repo.huaweicloud.com
    baseurl=https://repo.huaweicloud.com/centos/7/centosplus/$basearch/
    #mirrorlist=https://mirrorlist.centos.org/?release=7&arch=$basearch&repo=centosplus
    gpgcheck=1
    enabled=0
    gpgkey=https://repo.huaweicloud.com/centos/RPM-GPG-KEY-CentOS-7

    删掉/etc/yum.repos.d/ 下的CentOS-Base.repo 文件,使用vi CentOS-Base.repo建立文件后将上面替换完成的内容粘贴进去保存。

    yum clean all
    yum makecache

    再次安装

    sudo yum install docker-ce docker-ce-cli containerd.io

    image-20210701232958426

启动Docker
sudo service docker start

命令会重定向至 /bin/systemctl start docker.service

当然直接使用 systemctl start docker.service也无所谓

通过运行hello-world镜像,验证Docker引擎是否正确安装。
sudo docker run hello-world

image-20210701233742054

这个命令下载一个测试镜像并在一个容器中运行。当容器运行时,它会打印出一条信息消息并退出。

总结
结论1(推荐)
  1. 建立docker-ce.repo

    [docker-ce-stable]
    name=Docker CE Stable - $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/$basearch/stable
    enabled=1
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-stable-debuginfo]
    name=Docker CE Stable - Debuginfo $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/debug-$basearch/stable
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-stable-source]
    name=Docker CE Stable - Sources
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/source/stable
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-test]
    name=Docker CE Test - $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/$basearch/test
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-test-debuginfo]
    name=Docker CE Test - Debuginfo $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/debug-$basearch/test
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-test-source]
    name=Docker CE Test - Sources
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/source/test
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-nightly]
    name=Docker CE Nightly - $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/$basearch/nightly
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-nightly-debuginfo]
    name=Docker CE Nightly - Debuginfo $basearch
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/debug-$basearch/nightly
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg[docker-ce-nightly-source]
    name=Docker CE Nightly - Sources
    baseurl=https://repo.huaweicloud.com/docker-ce/linux/centos/7/source/nightly
    enabled=0
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/docker-ce/linux/centos/gpg

    /etc/yum.repos.d/ 下的使用vi docker-ce.repo建立文件后将上面的内容粘贴进去保存。

  2. 建立CentOS-Base.repo

    # CentOS-Base.repo
    #
    # The mirror system uses the connecting IP address of the client and the
    # update status of each mirror to pick mirrors that are updated to and
    # geographically close to the client.  You should use this for CentOS updates
    # unless you are manually picking other mirrors.
    #
    # If the mirrorlist= does not work for you, as a fall back you can try the
    # remarked out baseurl= line instead.
    #
    #[base]
    name=CentOS-7 - Base - repo.huaweicloud.com
    baseurl=https://repo.huaweicloud.com/centos/7/os/$basearch/
    #mirrorlist=https://mirrorlist.centos.org/?release=7&arch=$basearch&repo=os
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/centos/RPM-GPG-KEY-CentOS-7#released updates
    [updates]
    name=CentOS-7 - Updates - repo.huaweicloud.com
    baseurl=https://repo.huaweicloud.com/centos/7/updates/$basearch/
    #mirrorlist=https://mirrorlist.centos.org/?release=7&arch=$basearch&repo=updates
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/centos/RPM-GPG-KEY-CentOS-7#additional packages that may be useful
    [extras]
    name=CentOS-7 - Extras - repo.huaweicloud.com
    baseurl=https://repo.huaweicloud.com/centos/7/extras/$basearch/
    #mirrorlist=https://mirrorlist.centos.org/?release=7&arch=$basearch&repo=extras
    gpgcheck=1
    gpgkey=https://repo.huaweicloud.com/centos/RPM-GPG-KEY-CentOS-7#additional packages that extend functionality of existing packages
    [centosplus]
    name=CentOS-7 - Plus - repo.huaweicloud.com
    baseurl=https://repo.huaweicloud.com/centos/7/centosplus/$basearch/
    #mirrorlist=https://mirrorlist.centos.org/?release=7&arch=$basearch&repo=centosplus
    gpgcheck=1
    enabled=0
    gpgkey=https://repo.huaweicloud.com/centos/RPM-GPG-KEY-CentOS-7

    /etc/yum.repos.d/ 下使用vi CentOS-Base.repo建立文件后将上面的内容粘贴进去保存。

  3. 建立缓存

    yum clean all
    yum makecache

  4. 安装软件

    sudo yum install docker-ce docker-ce-cli containerd.io

结论2

直接从镜像站地址获取特定版本的软件及依赖(docker-ce版本20.10.7

yum install \
https://repo.huaweicloud.com/docker-ce/linux/centos/7/x86_64/stable/Packages/docker-ce-20.10.7-3.el7.x86_64.rpm \
https://repo.huaweicloud.com/docker-ce/linux/centos/7/x86_64/stable/Packages/docker-ce-rootless-extras-20.10.7-3.el7.x86_64.rpm \
https://repo.huaweicloud.com/docker-ce/linux/centos/7/x86_64/stable/Packages/docker-ce-cli-20.10.7-3.el7.x86_64.rpm \
https://repo.huaweicloud.com/docker-ce/linux/centos/7/x86_64/stable/Packages/docker-scan-plugin-0.8.0-3.el7.x86_64.rpm \
https://repo.huaweicloud.com/docker-ce/linux/centos/7/x86_64/stable/Packages/containerd.io-1.4.6-3.1.el7.x86_64.rpm \
http://mirror.centos.org/centos/7/extras/x86_64/Packages/fuse-overlayfs-0.7.2-6.el7_8.x86_64.rpm \
http://mirror.centos.org/centos/7/extras/x86_64/Packages/slirp4netns-0.4.3-4.el7_8.x86_64.rpm

这篇关于openEuler安装Docker和踩坑分析的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1117087

相关文章

Nginx分布式部署流程分析

《Nginx分布式部署流程分析》文章介绍Nginx在分布式部署中的反向代理和负载均衡作用,用于分发请求、减轻服务器压力及解决session共享问题,涵盖配置方法、策略及Java项目应用,并提及分布式事... 目录分布式部署NginxJava中的代理代理分为正向代理和反向代理正向代理反向代理Nginx应用场景

Redis中的有序集合zset从使用到原理分析

《Redis中的有序集合zset从使用到原理分析》Redis有序集合(zset)是字符串与分值的有序映射,通过跳跃表和哈希表结合实现高效有序性管理,适用于排行榜、延迟队列等场景,其时间复杂度低,内存占... 目录开篇:排行榜背后的秘密一、zset的基本使用1.1 常用命令1.2 Java客户端示例二、zse

Redis中的AOF原理及分析

《Redis中的AOF原理及分析》Redis的AOF通过记录所有写操作命令实现持久化,支持always/everysec/no三种同步策略,重写机制优化文件体积,与RDB结合可平衡数据安全与恢复效率... 目录开篇:从日记本到AOF一、AOF的基本执行流程1. 命令执行与记录2. AOF重写机制二、AOF的

解决docker目录内存不足扩容处理方案

《解决docker目录内存不足扩容处理方案》文章介绍了Docker存储目录迁移方法:因系统盘空间不足,需将Docker数据迁移到更大磁盘(如/home/docker),通过修改daemon.json配... 目录1、查看服务器所有磁盘的使用情况2、查看docker镜像和容器存储目录的空间大小3、停止dock

docker 重命名镜像的实现方法

《docker重命名镜像的实现方法》在Docker中无法直接重命名镜像,但可通过添加新标签、删除旧镜像后重新拉取/构建,或在DockerCompose中修改配置文件实现名称变更,感兴趣的可以了解一下... 目录使用标签(Tagging)删除旧的php镜像并重新拉取或构建使用docker Compose在Do

MyBatis Plus大数据量查询慢原因分析及解决

《MyBatisPlus大数据量查询慢原因分析及解决》大数据量查询慢常因全表扫描、分页不当、索引缺失、内存占用高及ORM开销,优化措施包括分页查询、流式读取、SQL优化、批处理、多数据源、结果集二次... 目录大数据量查询慢的常见原因优化方案高级方案配置调优监控与诊断总结大数据量查询慢的常见原因MyBAT

分析 Java Stream 的 peek使用实践与副作用处理方案

《分析JavaStream的peek使用实践与副作用处理方案》StreamAPI的peek操作是中间操作,用于观察元素但不终止流,其副作用风险包括线程安全、顺序混乱及性能问题,合理使用场景有限... 目录一、peek 操作的本质:有状态的中间操作二、副作用的定义与风险场景1. 并行流下的线程安全问题2. 顺

python依赖管理工具UV的安装和使用教程

《python依赖管理工具UV的安装和使用教程》UV是一个用Rust编写的Python包安装和依赖管理工具,比传统工具(如pip)有着更快、更高效的体验,:本文主要介绍python依赖管理工具UV... 目录前言一、命令安装uv二、手动编译安装2.1在archlinux安装uv的依赖工具2.2从github

MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决

《MyBatis/MyBatis-Plus同事务循环调用存储过程获取主键重复问题分析及解决》MyBatis默认开启一级缓存,同一事务中循环调用查询方法时会重复使用缓存数据,导致获取的序列主键值均为1,... 目录问题原因解决办法如果是存储过程总结问题myBATis有如下代码获取序列作为主键IdMappe

JDK8(Java Development kit)的安装与配置全过程

《JDK8(JavaDevelopmentkit)的安装与配置全过程》文章简要介绍了Java的核心特点(如跨平台、JVM机制)及JDK/JRE的区别,重点讲解了如何通过配置环境变量(PATH和JA... 目录Java特点JDKJREJDK的下载,安装配置环境变量总结Java特点说起 Java,大家肯定都