目录

一、简介

二、Docker的基本组成

三、Docker的安装

四、配置国内阿里云镜像加速

五、Hello World 上手实践

六、Docker底层原理


更多内容,前往 IT-BLOG

一、简介


Docker 是基于 Go 语言实现的云开源项目。主要目标是 “Build,Ship and Run Any App,Anywhere”,也就是通过对应用组件的封装分发部署运行等生命周期的管理,使用户的 APP(Web应用或数据库应用等等)及其运行环境能够做到“一次封装,到处运行”。

Linux 容器技术 的出现就解决了这样一个问题,而 Docker 就是在它的基础上发展过来的。将应用运行在 Docker 容器上面,而Docker容器在任何操作系统上都是一致的,这就实现了跨平台、跨服务器。只需要一次配置好环境,换到别的机器上就可以一键部署好,大大简化了操作。一句话解释:Docker 解决了运行环境和配置软件容器软件容器:每一个容器也称为集装箱对应一个开发工具,多个容器对应多个开发软件),方便做持续集成并有助于整体发布的容器虚拟化技术。

为什么说 Docker 是秒级别启动的?我们简单了解一下,Docker 使用的是一种虚拟化技术:Linux 容器(Linux Containers,缩写为 LXC)Linux 容器不是模拟一个完整的操作系统(Linux 就是模拟一个完整的操作系统),而是对进程进行隔离。有了容器,就可以将软件运行所需要的所有资源进行打包到一个隔离的容器中。容器与虚拟机不同,不需要捆绑一整套操作系统,只需要软件工作所需的库资源和设置。系统因此而变得高效轻量并保证部署在任何环境中的软件都始终如一地运行。
【比较 Docker 与传统虚拟化方式的不同之处】:
   ● 传统虚拟化技术是虚拟出一套硬件后,在其上运行一个完整操作系统,在此基础上运行所需的应用进程。
   ● 而容器内的应用进程直接运行于宿主的内核,容器内没有自己的内核,而且也没有进行硬件虚拟。因此容器比传统虚拟机更为轻便
   ● 每个容器之间互相隔离,每个容器有自己的文件系统,容器之间的进程不会相互影响,能够区分计算资源。

二、Docker的基本组成


前提:目前,CentOS 仅发行版本中的内核支持 Docker。
  ☛ Docker 运行在 CentOS7上,要求系统为64位、系统内核版本为 3.10以上。
  ☛ Docker 运行在 CentOS-6.5或更高的版本的 CentOS 上,要求系统为64位、系统内核版本为2.6.32-431或者更高版本。
  ☛ 通过uname -r 命令可以查看系统内核版本号,通过 cat /etc/redhat-release 命令查看 CentOS 版本。
Docker 的架构图:

Docker 的基本组成:镜像(image):就是一个只读的模板。镜像可以用来创建 Docker 容器,一个镜像可以创建多个容器。

Docker 面向对象
容器 对象
镜像

容器(Container):利用容器独立运行的一个或一组应用。容器是镜像创建的运行实例。它可以被启动开始停止删除。每个容器都是相互隔离的、保证安全的平台。可以把容器看做是一个简易版的 Linux环境(包括root用户权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。容器的定义和镜像几乎一模一样,也是一层一层的统一视角,唯一的区别是容器的最上面是可读可写的。
仓库(Repository):是集中存放镜像文件的场所。与仓库注册服务器(Registry)是有区别的。仓库注册服务器往往存放着多个仓库,每个仓库中又包含了多个镜像,每个镜像有不同的标签(tag)。仓库分为公有库(Public)和私有库(Private)两种形式。最大的公有库是Docker Hub,存放了数量庞大的镜像供用户下载。国内的公共仓库包括阿里云网易云等。
结论:Docker 本身是一个容器运行载体或称之为管理引擎。我们把应用程序和配置依赖打包好形成一个可交付的运行环境,这个打包好的运行环境就是 image 镜像文件,可以生成多个同时运行的实例。
  ●  image 文件生成的容器实例,本身就是一个文件,称为镜像文件。
  ●  一个容器运行一种服务,当我们需要的时候,就可以通过 docker客户端创建一个对应的运行实例,也就是我们的容器。
  ●  至于仓库,就是存放一堆镜像的地方,我们可以把镜像发布到仓库中,需要的时候从仓库中拉去下来即可。

三、Docker的安装


【1】yum install -y epel-release(Docker 使用 EPEL发布,RHEL 系的 OS 首先要确保已经持有 EPEL仓库,否则先检查OS的版本,然后安装相应的 EPEL包)

【2】yum install -y docker-io

【3】安装后的配置文件:/etc/sysconfig/docker
【4】启动Docker后台服务:service docker start
【5】docker version 验证。
 

四、配置国内阿里云镜像加速(默认的Docker Hub 为外国仓库,外国的仓库访问慢)


【1】阿里云镜像加速网址:https://promotion.aliyun.com/ntms/act/kubernetes.html(国外 Docker Hub 仓库访问慢,使用国内镜像网站)
【2】进入网站搜索“容器镜像服务”-“镜像加速器”,复制自己的加速地址:

【3】配置本地 Docker运行镜像加速器:经验证,coreos下是可以通过标准方式进行加速器的配置的。

# 创建并编辑文件
vi /etc/docker/daemon.json # 编辑文件内容
{
"registry-mirrors": ["https://xxxxxx.mirror.aliyuncs.com"]
} # 重启服务
systemctl daemon-reload
systemctl restart docker.service #验证
docker info

【4】Linux 系统配置下检查是否生效:ps -ef|grep docker (会显示你配置的阿里云仓库地址)

五、Hello World 上手实践


【1】运行 docker run hello-world

【2】run 命令的作用:

六、Docker底层原理


【1】Docker 是如何工作的?
Docker 是一个 Client-Server 结构的系统,Docker 守护进程运行在主机上,然后通过 Docker 连接从客户端访问,守护进程从客户端接收命令并管理运行在主机上的容器。容器,是一个运行时环境,就是我们所说的集装箱。
【2】为什么 Docker 比 VM 快?
   1)、Docker 有着比虚拟机更少的抽象层。由于 Docker 不需要 Hypervisor(结合下图)实现硬件资源虚拟化,运行在docker容器上的程序直接使用的都是实际物理机的硬件资源。因此在 CPU、内存利用率上 Docker将会在效率上有明显优势。
   2)、Docker 利用的是宿主机的内核,而不需要 Guest OS,因此,当新建一个容器时,docker 不需要和虚拟机一样重新加载一个操作系统内核。从而避免了加载操作系统内核浪费资源和时间的过程,当新建一个虚拟机时,虚拟机软件需要加载 Guest OS,这个过程是分钟级别的。而 docker由于直接利用宿主机的操作系统,省略了此过程,因此 docker容器只需要几秒钟。(参考下图)
 


----关注公众号,获取更多内容----

Docker 基础及安装的更多相关文章

  1. docker系列(一):docker基础与安装笔记

    1 什么是docker docker是基于GO语言编写的开源容器项目,诞生于2013年初,到目前为止,已经经历了6年的发展演变.现如今,docker已经非常火爆,特别是在一线IT企业,部署.运维等工作 ...

  2. docker基础——关于安装、常用指令以及镜像制作初体验

    为什么使用docker docker就是一个轻量级的虚拟机,他解决的是服务迁移部署的时候环境配置问题.比如常见的web服务依赖于jdk.Tomcat.数据库等工具,迁移项目就需要在新的机器重新配置这些 ...

  3. docker基础及安装

    Docker介绍: Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化.容器是完全使用沙箱机制 ...

  4. docker 基础 之安装

    一.安装 系统要求 Docker CE 支持 64 位版本 CentOS 7,并且要求内核版本不低于 3.10. CentOS 7 满足最低内核的要求,但由于内核版本比较低,部分功(如 overlay ...

  5. (二)docker的部署安装,配置,基础命令

    一.docker 的安装部署 这里不过多介绍,下面这两个linux发型版 安装可以参考 ubuntu的 docker-ce安装 centos7的 docker-ce安装 二.docker配置文件 重要 ...

  6. 2、Docker 基础安装和基础使用 一

    基础环境 本次环境使用Centos 7.x版本系统,最小化安装,系统基础优化配置请查看 Centos 7.x 系统基础优化 安装 使用命令:yum install docker-io -y [root ...

  7. [Docker基础]Docker安装教程

    Install Docker Docker支持几乎所有的Linux发行版,也支持Mac和Windows. 各操作系统的安装方法可参考Docker官网. 安装环境 ubuntu 16.04 Docker ...

  8. Docker基础教程(安装篇)

    Linux安装: 1.yum -y install docker-io 2.service docker start 3.chkconfig docker on Window安装: Docker 引擎 ...

  9. 『现学现忘』Docker基础 — 10、Docker的安装

    目录 1.前提 2.通过yum安装Docker (1)更新yum包 (2)移除旧的Docker版本 (3)安装必须的软件包 (4)设置稳定yum源仓库 (5)更新yum软件包索引 (6)开始安装Doc ...

  10. 『现学现忘』Docker基础 — 13、通过脚本安装Docker

    Docker官方提供方便用户操作的安装脚本,用起来是非常方便.但是要注意的是,使用脚本安装Docker,是安装最新版本的Docker. 注意:不建议在生产环境中使用安装脚本.因为在生产环境中一定不要最 ...

随机推荐

  1. pandas的数据结构--Series创建使用

    # 1. 使用Series创建一个空的系列:import pandas as pds=pd.Series()print(s)输出结果为:Series([], dtype: float64) # 2. ...

  2. OC底层知识之 性能优化

    一.CPU和GPU 的介绍 1.1.在屏幕成像的过程中,CPU和GPU起着至关重要的作用 CPU(Central Processing Unit,中央处理器),对象的创建和销毁.对象属性的调整.布局计 ...

  3. 5 RDD编程

    一.词频统计 1.读文本文件生成RDD lines 2.将一行一行的文本分割成单词 words flatmap() 3.全部转换为小写 lower() 4.去掉长度小于3的单词 filter() 5. ...

  4. centos7(虚拟机)下安装nginx

    centos7(虚拟机)下安装nginx 安装前准备 gcc yum install gcc-c++ pcre yum install -y pcre pcre-devel zlib yum inst ...

  5. 2022竞赛新方法学习1--学习Proceedings of SAT Competition 2022 : Solver and Benchmark Descriptions

    Proceedings of SAT Competition 2022 : Solver and Benchmark Descriptions https://helda.helsinki.fi/ha ...

  6. vscode 远程服务器同步

    1.下载 sftp 2. 在项目目录下新建sftp.json文件 3. 编辑sftp.json文件 { "name": "My Server", "h ...

  7. python中创建列表、元组、字符串、字典

    >>> a = ["aaa","bbb","ccc"] ## 列表,中括号,逗号 >>> type(a) ...

  8. HTML笔记(二) HTML标签元素

    一 常用的头部元素标签 <head>元素包含了所有的头部标签元素. 1.<title> <title>标签定义了HTML文档的标题,在HTML/XHTML文档中是必 ...

  9. 121、商城业务---订单服务---rabbitmq消息积压、丢失、重复等解决方案

  10. MySQL count(*) 和 count(字段) 区别

    count(字段)不会取Null的 select count(*) from test01                7条 select count(0) from test01          ...