《docker基础篇:2.Docker安装》包括前提说明、Docker的基本组成、Docker平台架构图解(架构版)、安装步骤、阿里云镜像加速、永远的HelloWorld、底层原理

news/2025/3/9 10:39:10/文章来源:https://www.cnblogs.com/bigcat26/p/18666347

@

目录
  • 2.Docker安装
    • 2.1前提说明
    • 2.2Docker的基本组成
    • 2.3Docker平台架构图解(架构版)
      • 2.3.1Docker平台架构图解(入门版)
      • 2.3.2Docker平台架构图解(架构版)
    • 2.4安装步骤
    • 2.5阿里云镜像加速
    • 2.6永远的HelloWorld
    • 2.7底层原理
  • 本人其他相关文章链接

2.Docker安装

2.1前提说明

CentOS Docker 安装

前提条件
目前,CentOS 仅发行版本中的内核支持 Docker。Docker 运行在CentOS 7 (64-bit)上,
要求系统为64位、Linux系统内核版本为 3.8以上,这里选用Centos7.x

查看自己的内核
uname命令用于打印当前系统相关信息(内核版本号、硬件架构、主机名称和操作系统类型等)。

2.2Docker的基本组成

Docker3大组成部分:

  • 镜像(image)
  • 容器(container)
  • 仓库(repository)

镜像(image)

Docker 镜像(Image)就是一个只读的模板。镜像可以用来创建 Docker 容器,一个镜像可以创建很多容器
它也相当于是一个root文件系统。比如官方镜像 centos:7 就包含了完整的一套 centos:7 最小系统的 root 文件系统。
相当于容器的“源代码”,docker镜像文件类似于Java的类模板,而docker容器实例类似于java中new出来的实例对象。

容器(container)

1 从面向对象角度
Docker 利用容器(Container)独立运行的一个或一组应用,应用程序或服务运行在容器里面,容器就类似于一个虚拟化的运行环境,容器是用镜像创建的运行实例。就像是Java中的类和实例对象一样,镜像是静态的定义,容器是镜像运行时的实体。容器为镜像提供了一个标准的和隔离的运行环境,它可以被启动、开始、停止、删除。每个容器都是相互隔离的、保证安全的平台

2 从镜像容器角度
可以把容器看做是一个简易版的 Linux 环境(包括root用户权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。

仓库(repository)

仓库(Repository)是集中存放镜像文件的场所。

类似于
Maven仓库,存放各种jar包的地方;
github仓库,存放各种git项目的地方;
Docker公司提供的官方registry被称为Docker Hub,存放各种镜像模板的地方。

仓库分为公开仓库(Public)和私有仓库(Private)两种形式。
最大的公开仓库是 Docker Hub(https://hub.docker.com/),
存放了数量庞大的镜像供用户下载。国内的公开仓库包括阿里云 、网易云等

小总结
需要正确的理解仓库/镜像/容器这几个概念:
Docker 本身是一个容器运行载体或称之为管理引擎。我们把应用程序和配置依赖打包好形成一个可交付的运行环境,这个打包好的运行环境就是image镜像文件。只有通过这个镜像文件才能生成Docker容器实例(类似Java中new出来一个对象)。

image文件可以看作是容器的模板。Docker 根据 image 文件生成容器的实例。同一个 image 文件,可以生成多个同时运行的容器实例。

镜像文件

  • image 文件生成的容器实例,本身也是一个文件,称为镜像文件。
    容器实例
  • 一个容器运行一种服务,当我们需要的时候,就可以通过docker客户端创建一个对应的运行实例,也就是我们的容器
    仓库
  • 就是放一堆镜像的地方,我们可以把镜像发布到仓库中,需要的时候再从仓库中拉下来就可以了。

2.3Docker平台架构图解(架构版)

2.3.1Docker平台架构图解(入门版)

Docker工作原理

在这里插入图片描述

2.3.2Docker平台架构图解(架构版)

首次懵逼正常,后续深入,先有大概轮廓,混个眼熟

整体架构及底层通信原理简述



2.4安装步骤

CentOS7安装Docker

官网:https://docs.docker.com/engine/install/centos/

安装步骤:

  • 1)确定你是CentOS7及以上版本
  • 2)卸载旧版本
  • 3)yum安装gcc相关
  • 4)安装需要的软件包
  • 5)设置stable镜像仓库
  • 6)更新yum软件包索引
  • 7)安装DOCKER CE
  • 8)启动docker
  • 9)测试
  • 10)卸载

注意点1:
步骤1中确定你是CentOS7及以上版本,执行命令:cat /etc/redhat-release

注意点2:
步骤2中卸载旧版本,https://docs.docker.com/engine/install/centos/

注意点3:
步骤3中yum安装gcc相关:

  • 1)CentOS7能上外网
  • 2)yum -y install gcc
  • 3)yum -y install gcc-c++

注意点4:
步骤4中安装需要的软件包,执行命令:yum install -y yum-utils
有官网要求,详情请看官网:https://docs.docker.com/engine/install/centos/

注意点5:
步骤5中设置stable镜像仓库,推荐设置阿里云镜像仓库,设置国外会非常非常慢
详情请看官网:https://docs.docker.com/engine/install/centos/

大坑:

yum-config-manager --add-repo https://download.docker.com/linux/centos/docker-ce.repo

推荐:

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

注意点6:
步骤6中更新yum软件包索引,执行命令:yum makecache fast

注意点7:
步骤7中安装DOCKER CE,执行命令:yum -y install docker-ce docker-ce-cli containerd.io
有官网要求和执行结果,详情请看官网:https://docs.docker.com/engine/install/centos/

注意点8:
步骤8中启动docker,执行命令:systemctl start docker
判断docker是否启动,可执行命令:ps -ef |grep docker

注意点9:
步骤9中测试
查看docker版本命令:docker version
启动docker命令:docker run hello-world,能打印如图就说明启动成功了。

注意点10:
步骤10中卸载,可按顺序执行命令:

  • 1)systemctl stop docker
  • 2)yum remove docker-ce docker-ce-cli containerd.io
  • 3)rm -rf /var/lib/docker
  • 4)rm -rf /var/lib/containerd

2.5阿里云镜像加速

使用步骤:
1)登录官网https://promotion.aliyun.com/ntms/act/kubernetes.html 注册一个属于自己的阿里云账户(可复用淘宝账号)
2)获得加速器地址连接
3)粘贴脚本直接执行
4)重启服务器

注意点1:
步骤2获得加速器地址连接中,有4步:

  • 登陆阿里云开发者平台

  • 点击控制台

  • 选择容器镜像服务

  • 获取加速器地址

注意点2:
步骤3粘贴脚本直接执行中,分2种:

  • 直接粘贴
mkdir -p /etc/docker
tee /etc/docker/daemon.json 
{"registry-mirrors": ["https://aa25jngu.mirror.aliyuncs.com"]
}
EOF

  • 或者分步骤都行

执行命令:
mkdir -p /etc/docker
vim /etc/docker/daemon.json

2.6永远的HelloWorld

docker run hello-world

承上启下这个图

问题:run干了什么?

2.7底层原理

问题:为什么Docker会比VM虚拟机快?

答案:

本人其他相关文章链接

1.《docker基础篇:1.Docker简介》包括Docker是什么、容器与虚拟机比较、能干嘛、去哪下
2.《docker基础篇:2.Docker安装》包括前提说明、Docker的基本组成、Docker平台架构图解(架构版)、安装步骤、阿里云镜像加速、永远的HelloWorld、底层原理
3.《docker基础篇:3.Docker常用命令》包括帮助启动类命令、镜像命令、有镜像才能创建容器,这是根本前提(下载一个CentOS或者ubuntu镜像演示)、容器命令、小总结
4.《docker基础篇:4.Docker镜像》包括是什么、分层的镜像、UnionFS(联合文件系统)、docker镜像的加载原理、为什么docker镜像要采用这种分层结构呢、docker镜像commit
5.《docker基础篇:5.本地镜像发布到阿里云》
6.《docker基础篇:6.本地镜像发布到私有库》包括本地镜像发布到私有库流程、docker regisry是什么、将本地镜像推送到私有库
7.《docker基础篇:7.Docker容器数据卷》包括坑、回顾下上一讲的知识点,参数V、是什么、更干嘛、数据卷案例
8.《docker基础篇:8.Docker常规安装简介》包括:docker常规安装总体步骤、安装tomcat、安装mysql、安装redis

重要信息

  • 官网:https://ais.cn/u/vEbMBz


本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/867953.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【逆向】查看APK文件源代码

1、先生成jar包 首先将apk修改文件名为zip或rar 首先将apk文件修改后缀名为zip,然后解压缩,得到解压之后的文件夹,文件夹中有一个classes.dex文件(这个文件就是java文件编译再通过dx工具打包而成的)zip->jar 接下来使用dex2jar:将apk反编译成java源码(classes.dex转化成…

读取HTTP首部

问题 希望读取一个HTTP请求首部。 解决方案 要读取一个首部,可以查看$_SERVER超级全局变量数组: //User-Agent首部 echo $_SERVER[HTTP_USER_AGENT]; 要读取所有首部,可以调用getallheaders(): $headers = getallheaders(); foreach($headers as $a=>$b){ print "$a:…

工地反光衣穿戴智能监测摄像机

工地反光衣穿戴智能监测摄像机系统通过技术创新和智能化应用,为建筑工地的安全管理提供了全新的解决方案。未来,随着技术的不断进步和应用场景的扩展,相信这类系统将在全球范围内得到广泛应用,为工人的安全作业提供更加可靠的保障和支持。在现代社会,建筑工地是高风险的工…

手把手带你搭建CI/CD工作流

一、什么是CI/CD? 持续集成(ContinousIntergration,CI)是在源代码变更后自动检测、拉取、构建和进行自动化测试的过程,属于开发人员的自动化流程。 该解决方案可以解决在一次开发中有太多应用分支,从而导致相互冲突的问题。其基本思路是,自动化监测代码仓库的变化并拉取…

非法闯入智能监测摄像机

非法闯入智能监测摄像机具备多项显著优势。首先,它能够智能分析画面中的人物和物体,通过对比数据库识别可疑目标,自动过滤正常活动,减少误报。其次,这些摄像机通常具备夜视功能和高清画质,确保在各种光线条件下都能清晰记录可疑行为。此外,很多智能摄像机支持远程监控,…

Java基础学习(六)

Java基础学习(六):面向对象 目录Java基础学习(六):面向对象概念类的结构对象的创建与初始化内存分析封装继承多态Instanceof 和 类型转换Static 关键字抽象类接口内部类 本文为个人学习记录,内容学习自 狂神说Java概念面向过程 vs 面向对象面向过程步骤清晰简单,第一步…

自如电费欺诈,屡教不改 All In One

自如电费欺诈,屡教不改 All In One 自如电费欺诈 常见手段汇总 💩 电表示数,自如抄表时候故意多抄、错抄! 导致使用电量和电费暴增,与国家电网 app 查询的实际使用量完全不一致!不严格按照国家和地方的居民电费分档计费标准的价格收费,随意向上跨档高价收费、多收费! …

插件广场

Obsidian 插件集市 (pkmer.cn)

ZooKeeper集群kafka集群安装

kafka的管理需要借助zookeeper完成,所以要先安装好zookeeper集群。 一、zookeeper集群安装 1.1 集群规划 在主机node1、node2和 node3 三个节点上都部署 Zookeeper。 1.2 解压安装 官网下载地址:https://zookeeper.apache.org/这里我安装的版本为3.5.7。在 node1服务器解压 Z…

Lec 12 进程间通信

Lec 12 进程间通信License 本内容版权归上海交通大学并行与分布式系统研究所所有 使用者可以将全部或部分本内容免费用于非商业用途 使用者在使用全部或部分本内容时请注明来源 资料来自上海交通大学并行与分布式系统研究所+材料名字 对于不遵守此声明或者其他违法使用本内容者…

老毛子PADAVAN为何不能挂载大容量移动硬盘/U盘?解决办法竟然如此简单

问题: 我用的是极路由B70,刷了PADAVAN,B70自身带有一个USB2.0,一个USB3.0,插入一个2TB的移动硬盘,NTFS格式,可以识别到,但没有挂载成功。 查看日志, 确实提示挂载失败,然后看到挂载的名字带有一些@@@@@。 解决办法: 联想自己移动硬盘的名字是中文。于是拔下移动硬盘,…

转:python的zmq模块

转自:https://www.jianshu.com/p/04660f746a16https://blog.csdn.net/SweetHeartHuaZai/article/details/1269348191、zmq介绍: 创建和销毁套接字:zmq.socket(), zmq.close() 配置和读取套接字:zmq.setsockopt(), zmq.getsockopt() 为套接字建立连接:zmq.bind(), zmq.conn…