​Docker​​​的优势很容易让Web开发人员所忽略。对于开发运维来说,它被认为太过技术性、没有必要。术语可能难以理解。教程从来没有解释如何在开发过程中使用​​Docker​​。在这里带大家一起来感受Docker在WEB开发中应用。

面向WEB开发的Docker(一)_应用程序

我们先来看看WEB开发过程中可能涉及的技术

  • ​HTML​​内容和模板
  • ​CSS​​样式表和预处理器,例如Sass
  • 前端​​JavaScript​​​,包括诸如​​React​​​,​​Vue.js​​​和​​Svelte​​之类的框架
  • 构建工具,例如​​bundlers​​​、​​minifiers​​​、​​etc​​。
  • Web服务器,例如​​NGINX​​​或​​Apache​
  • 服务器端和框架,包括​​Node.js​​​,​​PHP​​​,​​Python​​​,​​Ruby​​​,​​.NET​​等。
  • 数据库,例如​​MySQL​​​、​​MariaDB​​​、​​SQL Server​​​或​​MongoDB​
  • 其他用于缓存、消息队列、电子邮件、过程监视等的服务。
  • Git和Github用于源代码控制
  • 管理好这些可能是一个不小的挑战。

在开发过程如果要安装配置好以上环境,至少得几个小时!

1.1、“它可以在我的机器上运行,伙计”

想象一下你最近的应用程序非常成功。你不得不雇佣另一个开发者来给你更多的时间来赚钱。

它们出现在第一天的工作中,克隆你的代码库,启动代码,然后砰的一声,它失败了,出现一条模糊的错误消息。

调试可能会有所帮助,但是你的环境并不相同…

  • 你使用Mac,他们使用Windows
  • 你是使用Node.js v10开发的应用程序,已安装v14
  • 你使用的是MongoDB v3.6,它们在v4.2上

差异加剧。

也许可以在几个小时内解决这些问题,但是…

  • 能否使每个依赖项保持同步?
  • 随着团队和设备数量的增长,这可行吗?
  • 这些依赖关系在所有开发OS和生产服务器上是否可用?

一些公司会实施锁定的设备策略,在这种情况下,将无法使用最新或最合适的工具。这是你可能想到虚拟机?

1.2、虚拟机

该应用程序可以在虚拟机(VM)内运行,而不是限制设备和软件。VM允许将操作系统安装在仿真的硬件环境中。从本质上讲,它是在你的PC上运行的PC。

跨平台VM选项包括VMware​、VirtualBox​和Parallels Desktop。从理论上讲,可以使用你的应用程序及其所有依赖项来创建Linux(或其他)VM。VM只是数据:可以将其复制并在任何实际的Windows,macOS或Linux设备上运行。每个开发人员以及实时服务器都可以运行相同的环境。

不幸的是,虚拟机很快变得不切实际:

  • VM磁盘映像很大,难以复制
  • 单个VM可以自动更新,也可以由单个开发人员更新,因此与其他VM不同步
  • 一个VM需要大量的计算资源:它是一个完整的OS,在另一个OS内的仿真硬件上运行。

1.3、Docker交付

Docker解决了所有这些问题,甚至更多。无需在PC上安装依赖项,而可以在轻量,孤立的类似于VM的环境(称为容器)中运行它们。

在单个命令中,可以下载,配置和运行所需的服务或平台的任意组合。是的,只有一个命令。(诚然,这可能是一个非常复杂的命令,但这就是我们的目的!)

开发益处包括:

  • 所有开发人员都可以在Mac,Linux和Windows上使用相同的Docker容器
  • 应用程序的安装,配置,维护和测试变得更加容易
  • 应用程序在与开发PC隔离的虚拟环境中运行
  • 可以在同一台PC上同时使用同一应用程序或运行时的多个版本,例如PHP 5.6、7.0、7.4等。
  • 开发人员保留了本地开发的所有优势,可以毫无风险地进行试验。

类似的Docker环境也可以部署在生产环境中:

  • 可以简化持续集成和交付过程,以实现快速部署
  • 使用水平缩放可以改善性能。可以添加更多应用程序容器来应对增加的流量。
  • 服务更强大。如果容器发生故障,则可以在零停机时间内自动重新启动。
  • 可以保护应用程序。可以将容器配置为仅彼此通信,而不与外界通信。可以将MySQL数据库提供给WordPress容器,而无需将其暴露给主机OS或更高版本。

1.4、不,我仍然不相信

我也是一样不相信。

当我第一次遇到Docker时,这似乎是一个不必要的且有些艰巨的障碍。我在运行VM和配置依赖项方面有丰富的经验–当然不需要吗?

Docker文档很全面,但是学习曲线很陡。教程通常很差,并且:

  1. 假设读者完全理解所有术语,
  2. 无法解释或过度解释深奥的要点
  3. 很少讨论在开发过程中如何使用Docker。

当我开始时,我认为Docker无法处理动态应用程序重启或调试。教程经常声称每次代码更改都需要缓慢而麻烦的应用程序重建。于是我放弃了。

最终,另一位开发人员向我展示了Docker强大的应用场景,致使我深入研究了Docker几个月,学习研究的正是我缺少的。

1.5、来看看能做什么?

不管你使用哪种Web开发方法和堆栈,Docker都可以提供帮助。它在构建时提供一致的环境和或紧密匹配生产服务器上的依赖项。

Docker环境:

  1. 在没有活动/快速互联网连接的情况下可以工作(在旅行,演示中等期间很有用)
  2. 允许实验而没有风险。如果您不小心擦除了本地MySQL数据库,没人会介意。
  3. 不受成本和使用限制。

1.5.1、整体Web应用程序

整体应用程序包含前端和后端代码的混合。通常,该应用程序使用Web服务器,服务器语言运行时,数据存储以及客户端HTML,CSS,JavaScript和框架来呈现页面并提供API。WordPress是一个典型的例子。

Docker可用于复制该环境,因此所有依赖项均可在您的开发PC上使用。

1.5.2、无服务器Web应用程序

无服务器应用程序通常使用JavaScript框架在浏览器中实现大多数功能,以创建单页应用程序(SPA)。核心站点/应用程序将下载一次。

小型API可能以无服务器功能运行,从而提供了附加数据和服务。尽管名称如此,但服务器仍在使用中-但您无需担心对其进行管理。您创建一个从JavaScript Ajax请求按需启动的功能,例如,将表单数据通过电子邮件发送给销售团队的代码。

Docker可在开发环境中用于:

  • 运行构建过程,例如JavaScript模块捆绑和Sass预处理
  • 服务网络应用程序,以及
  • 模拟用于无服务器功能测试的基础架构。

1.5.3、静态站点

使用构建过程构建静态站点,该过程将内容(markdown文件,JSON数据,数据库字段等)放入模板中,以创建包含静态HTML,CSS,JavaScript和媒体文件的文件夹。这些预渲染的文件可以部署在任何地方:不需要服务器端运行时或数据库。

静态站点通常称为JAMstack(JavaScript,API和Markdown)。所有内容都在可能的情况下预先呈现,但是动态服务(例如站点搜索)可以采用基于服务器的API。

Docker可用于在任何开发PC上提供可复制的构建环境。