docker是一个用Go语言实现的开源项目,可以让我们方便的创建和使用容器,docker将程序以及程序所有的依赖都打包到docker container,这样你的程序可以在任何环境都会有一致的表现,这里程序运行的依赖也就是容器就好比集装箱;容器所处的操作系统环境就好比货船或港口,程序的表现只和集装箱有关系(容器),和集装箱放在哪个货船或者哪个港口(操作系统)没有关系。
因此我们可以看到docker可以屏蔽环境差异,也就是说,只要你的程序打包到了docker中,那么无论运行在什么环境下程序的行为都是一致的,不会再有“在我的环境上可以运行的啊!!!”
环境隔离('隔离,安全')
Docker 实现了资源隔离,一台机器运行多个容器互无影响。
更高效的资源利用(节约成本)
Docker 容器的运行不需要额外的虚拟化管理程序的支持,它是内核级的虚拟化,可以实现更高的性能,同时对资源的额外需求很低。
更快速的交付部署(敏捷)
使用 Docker,开发人员可以利用镜像快速构建一套标准的研发环境,开发完成后,测试和运维人员可以直接通过使用相同的环境来部署代码。
更易迁移扩展(可移植性)
Docker 容器几乎可以在任意的平台上运行,包括虚拟机、公有云、私有云、个人电脑、服务器等,这种兼容性让用户可以在不同平台之间轻松的迁移应用。
更简单的更新管理(高效)
使用 Dockerfile,只需要很少的配置修改,就可以替代以往大量的更新工作。并且所有修改都是以增量的方式进行分发和更新,从而实现自动化和高效的容器管理。
对于认为Docker是开发人员专属工具的人来说,恐怕要准备好颠覆自己的认知了。
容器化应用需要有地方运行,也需要有人来管理。如果认为只是开发人员来管理它,那就大错特错了,事实上运维需要构建和运行高性能、生产级别的Docker基础架构。对于专注于运维工作却尚未掌握Docker的朋友来说,日子恐怕不太好过。不过不必焦虑,本文将帮你掌握Docker。
本文将从目录、主要内容和总结这三部分的结构给大家介绍,希望大家能够喜欢!!
本文总共分为17章的内容,从Docker概览和Docker技术两部分进行全面解析,深入浅出地介绍了Cocker 的相关知识,清晰详细的操作步骤结合大量的实际代码帮助读者学以致用,将Docker知识应用到真实的项目开发当中。
第1章容器发展之路;现在容器无疑成为了一种潮流,为了让读者更加全面地了解Docker, 本文就从容器的发展之路开始娓娓道来。
本章主要向读者介绍如下内容、
●容器为什么出现。
●容器的作用。
●容器的应用场景。
第2章走进Docker;本章介绍了Docker 公司,这是一家位于旧金山的立志于变更软件行业的科技创业公司。可以说他们是现今容器革命的先行者和推动者。但是现在已经形成了一个由作者和竞争者组成的大型生态。
Docker项目是开源的,其上游源码位于GitHub的moby/moby库。
开放容器计划(OCI )在容器运行时格式和容器镜像格式的标准化方面发挥了重要作用。
第3章Docker安装;Docker在Linux和Windows中都是可用的,并且分为社区版(CE)和企业版(EE)。在本章中,主要向读者介绍了在Windows10、Mac OS X、Linux以及Windows Server 2016下的几种安装Docker的方式。
本章还介绍了如何在Ubuntu 16.04和Windows Server 2016环境中升级Docker引擎,这也是两种常见的配置场景。
本章中读者还可以了解到选择正确的存储驱动对于在Linux生产环境中使用Docker非常重要。
第4章纵观Docker;在运维部分,我们下载了Docker镜像,启动容器并且登录到容器内部执行相应的命令,最后停止容器并删除。
在开发部分,我们完成了简单应用的容器化过程:从GitHub拉取应用源代码,并且通过Dockerfile中的指令,将应用代码构建到镜像之中。接着运行了该容器化应用。
本章的整体介绍能帮助读者更好地理解接下来的章节,包括镜像与容器相关细节。
第二部分Docker技术;
第5章Docker引擎;在本章,我们将快速了解Docker引擎的内部原理。
即便不了解本章的内容,也不影响使用Docker。 因此,读者可自行跳过本章。然而,只有理解了某项技术的底层原理,才能算作真正掌握了它。所以,为了成为真正的Docker大师,建议阅读本章内容。
本章将仅介绍理论,而不涉及相关练习。
本章属于本文技术篇的一部分,因此按照惯例仍然采用“三步法”,分为3个小节来介绍。
简介:在排队购买咖啡的时候就能够读完的,两到三段的概述。
●详解: 详细介绍本章知识的细节。
●命令:快速回顾本章中了解到的相关命令。
下面进入Docker引擎的学习吧!
第6章Docker镜像;在本章中会深入介绍Docker镜像的相关内容。本章的目标是能帮助读者建立Docker 镜像的整体认知,并且了解镜像的相关基础操作。在接下来的章节中,本文会向读者展示如何构建一个包含应用的镜像(应用容器化)。
按照惯例,本章节分为如下3个部分。
●简介。
●详解。
●命令。
接下来开始关于镜像的学习吧!
第7章Docker容器;现在读者已经对镜像有所了解,是时候开始学习容器了。因为本文主要介绍Docker,所以这里容器特指Docker容器。但是,Docker已经基本实现由OCI发布的镜像和容器标准。这意味着读者在Docker容器这里学习的内容,同样可以在其他实现了OCI标准的容器运行时上应用。
本章内容依旧分为3个部分。
接下来就开始学习容器吧!
第8章应用的容器化;Docker的核心思想就是如何将应用整合到容器中,并且能在容器中实际运行。
将应用整合到容器中并且运行起来的这个过程,称为“容器化" ( Containerizing),有时也叫作“Docker 化”( Dockerizing )。
本章将逐步介绍容器化-个简单的Linux Web应用的过程。如果读者没有一个Linux 的Docker环境来跟进练习,那么可以免费使用Play With Docker。只需使用浏览器打开Play WithDocker的页面,并启动若干Linux Docker 节点即可。这是我最喜欢的启动和练习Docker的方式。
本章的内容主要分为3个部分。
●简介。
●详解。
●命令。
下面就开始本章的内容吧!
第9章使用Docker Compose部署应用;本章介绍如何使用Docker Compose部署多容器的应用。
Docker Compose与Docker Stack非常类似。本章主要介绍Docker Compose,它能够在Docker节点上,以单引擎模式( Single Engine Mode )进行多容器应用的部署和管理。下一章将介绍DockerStack,它能够以Swarm模式对Docker节点上的多容器应用进行部署和管理。
本章依然分为以下3个部分。
●简介。
●详解。
●命令。
第10章Docker Swarm;本文至此已介绍了如何安装Docker、拉取镜像以及使用容器,接下来需要探讨的话题将是关于规模(Scale)方面的。下 面有请Docker Swarm登场。
概括来说,Swarm 有两个核心组件。
●安全集群。
●编排引擎。
按照惯例,本文分为以下3个部分。
●简介。
●详解。
●命令。
本章示例及其输出将基于Linux 系统的Swarm。 然而,大多数命令和功能在Windows 版Docker.上同样适用。
第11章Docker网络;网络已经无处不在。每当基础设施出现问题时,被抱怨的通常是网络。很大 一部分原因是,网络负责连接一切无网络, 无APP!在Docker早期阶段,网络设计确实非常复杂真的很复杂!那时候配置网络几乎是-一种乐趣。
在本章中,主要介绍了Docker网络体系的基本原理,比如容器网络模型( Container NetworkModel, CNM )以及Libnetwork,同时还会进行实际操作来搭建几种网络。
按照惯例,本章分以下3个部分。
●简介。
●详解。
●命令。
第12章Docker覆盖网络;在大部分与容器网络相关的场景中,覆盖网络都处于核心地位。在本章中会介绍原生Docker覆盖网络的基本要素,以及覆盖网络在Docker Swarm集群中的实现。
Docker覆盖网络在Windows.上基本与Linux相同。这意味着本章示例在Windows和Linux上都会生效。
本章内容按惯例分为如下3个部分。
●简介。
●详解。
●命令。
一起开启网络魔法之旅吧!
第13章****卷与****持久化数据;是时候了解Docker如何管理数据了。本书会关注持久化和非持久化数据。但在本章,会着重关注持久化数据。
本章内容按惯例分为3个部分。
●简介。
●详解。
●命令。
第14章使用Docker Stack部署应用;大规模场景下的多服务部署和管理是一件很难的事情。
幸运的是,Docker Stack为解决该问题而生! Docker Stack通过提供期望状态、滚动升级、简单易用、扩缩容、健康检查等特性简化了应用的管理!这些功能都封装在-一个完美的声明式模型当中。太赞了!
如果读者现在是第-一次接触这些术语,或者感觉难以理解,请不要担心!在阅读完本章后,就能理解这些概念了!
本章内容按惯例分为3个部分。
●简介。
●详解。
命令。
第15章Docker安全;好的安全性是基于分层隔离的,而Docker恰好有很多分层。Docker 支持所有主流Linux 安全机制,同时Docker自身还提供了很多简单的并且易于配置的安全技术。
本章主要介绍Docker中保障容器安全运行的一些技术。
在本章的深入探索中,内容划分为以下两部分。
●Linux安全技术。
●Docker平台安全技术。
本章大部分章节内容仅适用于Linux。但是,Docker平台安全技术部分是跨平台的,可以应用于Linux以及Windows。
第16章企业版工具;在本章中,主要关注Docker提供的一- 些企业级工具,包括如何安装、如何配置、如何备份以及存储。
本章内容会比较长,并且大部分都是技术细节的分步介绍。本书尽量保证内容有趣,不过这确实很难。
本章会集中关注Docker公司提供的工具。
让我们直接开始吧。
第17章企业级特性;本章承接第16章的内容,主要涉及Docker 通用控制平面和Docker可信镜像仓库服务提供的企业级特性。
本章将假设读者已经阅读了第16 章的内容,并且了解如何安装和配置它们,以及如何执行备份和恢复操作。
本章内容将分两部分展开。
●简介。
●详解。
本文适合学习的读者
本文适合对Docker感兴趣的、新手、Docker 技术开发人员以及运维人员阅读,也可作为Docker认证工程师考试的参考。
希望大家能把本文的内容认真学习到手,并且能够灵活运用到工作当中,增加自己的技术深度和广度,让自己变得更有价值!