1.1、Docker 简介

Docker 简介与安装

Docker 教程

Docker 是一个开源的应用容器引擎,基于 Go 语言 并遵从 Apache2.0 协议开源。

Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化。

容器是完全使用沙箱机制,相互之间不会有任何接口(类似 iPhone 的 app ),更重要的是容器性能开销极低。

什么是容器?

  • 一种虚拟化的方案
  • 操作系统级别的虚拟化
  • 只能运行相同或相似内核的操作系统
  • 依赖于 Linux 内核特性: NamespaceCgroups(Control Group)

注意:
1、 Namespace命名空间
编程语言:封装——》代码隔离
操作系统:系统资源的隔离;进程、网络、文件系统…
五种命名空间:
PID(Process ID):进程隔离
NET(Network):管理网络接口
IPC(InterProcess Communication):管理跨进程通信的访问
MNT(Mount):管理挂载点
UTS(Unix Timesharing System):隔离内核和版本标识

2、 Cgroups(Control Group)控制组——为容器而生
用来分配资源、来源于谷歌
资源限制、优先级设定、资源计量、资源控制

Docker 的目标?

提供简单轻量的建模方式:很容易开启
职责的逻辑分离:开发人员只需关注容器中运行的应用程序,运维人员管理容器
快速高效的开发生命周期:缩短开发、测试、部署、上线运行的开发周期
鼓励使用面向服务的架构:单个容器只运行一个程序

Docker 的使用场景?

1、 使用 Docker 容器开发、测试、部署服务
2、 创建隔离的运行环境
3、 搭建测试环境
4、 构建多用户的平台即服务( PaaS )基础设施
5、 提供软件即服务( SaaS )应用程序
6、 高性能、超大规模的宿主机部署

Docker 的应用场景

  • Web 应用的自动化打包和发布。
  • 自动化测试和持续集成、发布。
  • 在服务型环境中部署和调整数据库或其他的后台应用。
  • 从头编译或者扩展现有的 OpenShiftCloud Foundry 平台来搭建自己的 PaaS 环境。

Docker 的基本组成?

1、 Docker Client 客户端 和 Docker Daemon 守护进程
C/S 架构
本地/远程

2、 Docker Image 镜像
容器的基石
层叠的只读文件系统
联合加载( union mount

3、 Docker Container 容器
通过镜像启动
启动和执行阶段
写时复制( copy on write

4、 Docker Registry 仓库
用来保存用户构建的镜像
公有( Docker Hub )/私有

Docker 的优点

  • 1、简化程序:
    Docker 让开发者可以打包他们的应用以及依赖包到一个可移植的容器中,然后发布到任何流行的 Linux 机器上,便可以实现虚拟化。Docker改变了虚拟化的方式,使开发者可以直接将自己的成果放入Docker中进行管理。方便快捷已经是 Docker的最大优势,过去需要用数天乃至数周的 任务,在Docker容器的处理下,只需要数秒就能完成。

  • 2、避免选择恐惧症:
    如果你有选择恐惧症,还是资深患者。Docker 帮你 打包你的纠结!比如 Docker 镜像;Docker 镜像中包含了运行环境和配置,所以 Docker 可以简化部署多种应用实例工作。比如 Web 应用、后台应用、数据库应用、大数据应用比如 Hadoop 集群、消息队列等等都可以打包成一个镜像部署。

  • 3、节省开支:
    一方面,云计算时代到来,使开发者不必为了追求效果而配置高额的硬件,Docker 改变了高性能必然高价格的思维定势。Docker 与云的结合,让云空间得到更充分的利用。不仅解决了硬件管理的问题,也改变了虚拟化的方式。

Ⅱ Docker 架构

Docker 使用客户端-服务器 (C/S) 架构模式,使用远程API来管理和创建Docker容器。

Docker 容器通过 Docker 镜像来创建。

容器与镜像的关系类似于面向对象编程中的对象与类。

Docker 面向对象
容器 对象
镜像

docker-1.png

Docker 镜像(Images) Docker 镜像是用于创建 Docker 容器的模板
Docker 容器(Container) 容器是独立运行的一个或一组应用
Docker 客户端(Client) Docker 客户端通过命令行或者其他工具使用 Docker API (https://docs.docker.com/reference/api/docker_remote_api) 与 Docker 的守护进程通信
Docker 主机(Host) 一个物理或者虚拟的机器用于执行 Docker 守护进程和容器
Docker 仓库(Registry) Docker 仓库用来保存镜像,可以理解为代码控制中的代码仓库。Docker Hub(https://hub.docker.com) 提供了庞大的镜像集合供使用
Docker Machine Docker Machine是一个简化Docker安装的命令行工具,通过一个简单的命令行即可在相应的平台上安装Docker,比如VirtualBox、 Digital Ocean、Microsoft Azure。

猜你喜欢

转载自blog.csdn.net/weixin_42112635/article/details/86473895
今日推荐