草庐IT

10分钟了解微服务、容器和Kubernetes

好大的泡泡 2023-03-28 原文

什么是微服务?

什么是微服务?你应该使用微服务吗?微服务与容器和 Kubernetes 有什么关系?如果这些问题在您的日常生活中不断出现,那么这篇文章适合您。

从根本上说,微服务只是一个运行在服务器或虚拟计算实例上并响应网络请求的计算机程序。这与典型的Java、Django、Node.js应用程序没有什么不同。事实上,您可能会发现您的组织中已经部署了十几个微服务。

没有任何新的神奇技术使您的应用程序变成微服务,微服务不是由它的构建方式来定义的,而是由它如何适应更广泛的系统或解决方案来定义的。

那么是什么使服务成为微服务呢?一般来说,微服务的范围更窄,专注于做好较小的任务。让我们通过看一个例子来进一步探索。

让我们看看在Amazon上为您提供产品的页面。它包含几个信息块,可能是从不同的数据库中检索到的:

  • 产品描述,包括价格、标题、照片等。
  • 推荐项目,即其他人购买的类似书籍。
  • 与此项目相关的赞助商列表。
  • 关于本书作者的信息。
  • 顾客评论。
  • 您自己在亚马逊商店中浏览其他商品的历史记录。

如果您要快速编写用于此列表的代码,那么简单的方法将如下所示:

当用户从浏览器发起请求时,它将由Web应用程序(Linux 或 Windows 进程)提供服务。通常,被调用的应用程序代码片段称为请求处理程序。处理程序内部的逻辑将依次多次调用数据库,获取呈现页面所需的信息并将其拼接在一起,然后呈现要返回给用户的网页。

很简单吧?事实上,许多开发类的书籍都有类似这样的教程和示例。那么,你可能会问,为什么要使用微服务把事情复杂化?

想象一下随着应用程序的增长和越来越多的工程师参与其中会发生什么。上面例子中的推荐引擎是由一群程序员和数据科学家维护的。有几十个不同的团队负责渲染该页面的某些组件。这些团队中的每一个通常都希望获得以下自由:

  1. 更改他们的数据库架构。
  2. 快速且频繁的将他们的代码发布到生产环境中。
  3. 使用他们选择的编程语言或数据存储开发工具。
  4. 在计算资源和开发人员生产力之间做出自己的权衡。
  5. 拥有自己偏好的维护或监控工具。

可以想象,随着时间的推移,让整个团队就发布应用程序的新版本的所有内容达成一致将变得更加困难。

解决方案是将组件拆分为更小的、独立的服务(又名微服务)。

请求处理程序将传入的页面请求分解为几个专门的请求,并将它们转发给相应的微服务,这些微服务分别使用独立的进程和资源运行。

微服务被分离出来后,每个开发它们的开发团队都可以:

  • 随心所欲地部署他们的服务,而不会干扰其他团队。
  • 以他们认为合适的方式扩展他们的服务。例如,使用他们选择的 AWS 实例类型,或者可能在专用硬件上运行。
  • 拥有自己特定于其服务的监控、备份和灾难恢复。

什么是容器?

从技术上讲,容器只是一个从可执行文件产生的进程,运行在服务器上,它有一些限制,例如:

  • 容器不允许看到所有文件系统,它只能访问其中的指定部分。
  • 一个容器不允许使用所有的CPU或内存。
  • 容器在如何使用网络方面受到限制。

大多数时候,当人们说「容器」时,他们不仅仅指的是Linux进程,还指的是可执行文件的打包和存储方式。

类似的工具Docker允许开发人员获取他们的可执行文件及其依赖项,以及他们想要的任何其他文件,并将它们全部打包成一个文件。这项技术与tarball之类的打包工具没有太大区别。Docker 还允许包含一些额外的指令和配置来运行这个打包的可执行文件。通常这些文件称为镜像。

但为了简单起见,请记住:

  • 一个容器是一个Linux进程
  • 镜像是Linux可执行文件与它的依赖和配置文件的打包

镜像是可以在任何安装了Docker的机器上运行的,因此容器化技术使得开发人员在不同的环境中部署程序更加容易。

微服务和容器有什么区别?

我们刚刚了解到容器只是一种打包、部署和运行程序或者进程的方法。您可以将一个巨大的单体应用程序作为容器,也可以拥有一群完全不使用容器技术的微服务。

容器是一种有用的资源分配和共享技术。这是开发运维人员感到兴奋的事情。

微服务是一种软件设计模式。这是开发人员感到兴奋的事情。

它们是相关的,但不需要彼此。您可以将单体应用部署为容器,也可以拥有不受限制的、非容器化的微服务。

什么时候使用微服务?

微服务背后的想法并不新鲜。十几年来,软件架构师一直致力于将单体应用程序分离为可重用的组件。

微服务的好处很多,包括:

  • 更简单的自动化测试。
  • 快速灵活的部署模式。
  • 更高的整体弹性。

采用微服务的另一个好处是能够为工作选择最佳工具。应用程序的某些部分可以从 C++ 的速度中受益,而其他部分可以从更高级别语言(例如Python或JavaScript)的生产力提高中受益。

微服务的缺点包括:

  • 需要更仔细的规划。
  • 更高的研发投入。
  • 过度工程的诱惑。

如果应用程序和开发团队足够小并且工作量不具有挑战性,则通常无需使用微服务。但是,如果您开始看到微服务的利大于弊,这里有一些具体的设计注意事项:

  1. 计算和存储分离

    随着您对 CPU 能力和存储需求的增长,这些资源具有非常不同的扩展成本和特性。从一开始就不必依赖本地存储,这将使您能够相对轻松地适应未来的工作负载。这既适用于文件系统等简单的存储形式,也适用于数据库等更复杂的解决方案。

  2. 异步处理

    通过添加越来越多的相互调用的子程序或对象来逐步构建应用程序的传统方法随着工作负载的增长而停止工作,并且应用程序本身必须跨多台机器甚至数据中心扩展。将需要围绕事件驱动模型重新构建应用程序。

  3. 拥抱消息总线

    随着您的单体应用程序被分解为事件处理程序和事件发射器,就需要一个健壮、高性能和灵活的消息总线。有多种选择,选择取决于应用程序规模和复杂性。对于一个简单的应用,像Redis这样的东西就可以了。如果您的应用程序足够复杂,您可能需要一个Kafka。

  4. API 版本控制

    由于您的微服务将使用彼此的 API 通过总线相互通信,因此设计用于保持向后兼容性的架构将是至关重要的。开发团队必须在永远支持旧 API 和保持更高的开发速度之间达成合理的妥协。这也意味着 API 设计成为一项重要的技能。频繁的API更改是团队无法高效开发复杂微服务的原因之一。

  5. 重新考虑您的安全性

    许多开发人员没有意识到这一点,但迁移到微服务为更好的安全模型创造了机会。由于每个微服务都是一个专门的进程,因此最好只允许它访问所需的资源。这样,仅一个微服务中的漏洞就不会将系统的其余部分暴露给攻击者。

Kubernetes 与微服务有什么关系?

Kubernetes太复杂了,在本文中不会详细描述,但值得对其进行概述,因为很多人在有关微服务的对话中都会提到它。

严格来说,Kubernetes(又名 K8s)的主要好处是通过跨多个进程高效共享计算资源来提高基础设施利用率。Kubernetes是动态分配计算资源以满足需求的大师。这允许组织避免为他们不使用的计算资源付费。

当您将单体应用程序分解为单独的、松散耦合的微服务时,您的团队将获得更多的自主权和自由度。然而,在与运行微服务的基础设施进行交互时,他们仍然必须密切合作。

您必须解决以下问题:

  • 预测每个服务需要多少计算资源。
  • 这些要求在负载下如何变化。
  • 如何划分基础设施分区并将它们划分到微服务之间。
  • 实施资源限制。

Kubernetes非常优雅地解决了这些问题,并提供了一个通用框架来描述、检查和推理基础设施资源的共享和利用。这就是为什么采用Kubernetes作为微服务架构的一部分是一个好主意。

然而,Kubernetes是一项需要学习的复杂技术,而且更难管理。如果允许,您可以利用第三方提供的服务,我们建议尝试使用 StarOS,这是一个一站式云原生在线开发平台,底层技术基于Kubernetes。

StarOS 通过架构图模型,将微服务的依赖关系固化,完成了对整个应用的封装,从而实现了应用与环境的解耦。无论是应用复制,还是应用迁移,都得心应手。并且基于基础设施下沉的理念,将底层的容器集群资源、运维管理工具,以及中间件、环境配置等全部下沉为平台能力,真正做到了一站式,而且开箱即用。

StarOS 还为研发团队提供了多职能、多场景的多人在线协作研发工具,支持研发工作中多种输出物的在线编辑交付,让您在异地协同,远程办公的时候,尽享便利。

总结一下:

  1. 容器只是具有应用限制的Linux进程,限制的示例包括允许进程使用多少CPU或内存。Docker允许开发人员将他们的可执行文件与依赖项和附加配置打包在一起,这些包被称为镜像。
  2. 微服务并不新鲜,这是一种软件设计模式,由于互联网公司的规模不断扩大,它越来越受欢迎。微服务不一定要容器化,类似地,单体应用程序可以是微服务。
  3. 小项目不应该回避整体设计。它为较小的团队提供更高的生产力。
  4. Kubernetes是由多个微服务组成的复杂应用程序的绝佳平台。
  5. Kubernetes是一个复杂的系统。

有关10分钟了解微服务、容器和Kubernetes的更多相关文章

  1. Observability:从零开始创建 Java 微服务并监控它 (二) - 2

    这篇文章是继上一篇文章“Observability:从零开始创建Java微服务并监控它(一)”的续篇。在上一篇文章中,我们讲述了如何创建一个Javaweb应用,并使用Filebeat来收集应用所生成的日志。在今天的文章中,我来详述如何收集应用的指标,使用APM来监控应用并监督web服务的在线情况。源码可以在地址 https://github.com/liu-xiao-guo/java_observability 进行下载。摄入指标指标被视为可以随时更改的时间点值。当前请求的数量可以改变任何毫秒。你可能有1000个请求的峰值,然后一切都回到一个请求。这也意味着这些指标可能不准确,你还想提取最小/

  2. 由于 libgmp.10.dylib 的问题,Ruby 2.2.0 无法运行 - 2

    我刚刚安装了带有RVM的Ruby2.2.0,并尝试使用它得到了这个:$rvmuse2.2.0--defaultUsing/Users/brandon/.rvm/gems/ruby-2.2.0dyld:Librarynotloaded:/usr/local/lib/libgmp.10.dylibReferencedfrom:/Users/brandon/.rvm/rubies/ruby-2.2.0/bin/rubyReason:Incompatiblelibraryversion:rubyrequiresversion13.0.0orlater,butlibgmp.10.dylibpro

  3. ruby - 了解在 Ruby 中与 lambda 一起使用的 inject 行为 - 2

    我经常将预配置的lambda插入可枚举的方法中,例如“map”、“select”等。但是“注入(inject)”的行为似乎有所不同。例如与mult4=lambda{|item|item*4}然后(5..10).map&mult4给我[20,24,28,32,36,40]但是,如果我制作一个2参数lambda用于像这样的注入(inject),multL=lambda{|product,n|product*n}我想说(5..10).inject(2)&multL因为“inject”有一个可选的单个初始值参数,但这给了我......irb(main):027:0>(5..10).inject

  4. ruby-on-rails - 如何测试自己对 Ruby/ROR 的了解? - 2

    是否有self验证的问题列表。看着那个,我可以确定我知道。我应该复习一下。在学习的过程中,我列了一个这样的list,但它只包含我在某处听说过的项目。我需要一段时间才能找到新的东西。 最佳答案 以下是针对ruby​​和Rails的一些测试列表。证书名称:RubyonRails谁提供:oDeskIncorporation认证费用:免费网站:https://www.odesk.com/tests/985?pos=0证书名称:RubyonRails提供者:Techgig.com(TimesBusinessSolutionsLimited(T

  5. ruby - ri 有空文件 – Ubuntu 11.10, Ruby 1.9 - 2

    我正在运行Ubuntu11.10并像这样安装Ruby1.9:$sudoapt-getinstallruby1.9rubygems一切都运行良好,但ri似乎有空文档。ri告诉我文档是空的,我必须安装它们。我执行此操作是因为我读到它会有所帮助:$rdoc--all--ri现在,当我尝试打开任何文档时:$riArrayNothingknownaboutArray我搜索的其他所有内容都是一样的。 最佳答案 这个呢?apt-getinstallri1.8编辑或者试试这个:(非rvm)geminstallrdocrdoc-datardoc-da

  6. ruby-on-rails - gem install rmagick -v 2.13.1 错误 Failed to build gem native extension on Mac OS 10.9.1 - 2

    我已经通过提供MagickWand.h的路径尝试了一切,我安装了命令工具。谁能帮帮我?$geminstallrmagick-v2.13.1Buildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingrmagick:ERROR:Failedtobuildgemnativeextension./Users/ghazanfarali/.rvm/rubies/ruby-1.8.7-p357/bin/rubyextconf.rbcheckingforRubyversion>=1.8.5...yescheckingfor/

  7. ruby-on-rails - 了解 "attribute_will_change!"方法 - 2

    我想覆盖store_accessor的getter。可以查到here.代码在这里:#Fileactiverecord/lib/active_record/store.rb,line74defstore_accessor(store_attribute,*keys)keys=keys.flatten_store_accessors_module.module_evaldokeys.eachdo|key|define_method("#{key}=")do|value|write_store_attribute(store_attribute,key,value)enddefine_met

  8. ruby - 安装 tiny_tds 在 mac os 10.10.5 上出现错误 - 2

    我正在使用macos,我想使用ruby​​驱动程序连接到sqlserver。我想使用tiny_tds,但它给出了缺少free_tds的错误,但它已经安装了。怎么能过这个?~brewinstallfreetdsWarning:freetds-0.91.112alreadyinstalled~sudogeminstalltiny_tdsBuildingnativeextensions.Thiscouldtakeawhile...ERROR:Errorinstallingtiny_tds:ERROR:Failedtobuildgemnativeextension.完整日志如下:/System

  9. ruby - 我怎样才能更好地了解/了解更多关于 Ruby 的知识? - 2

    按照目前的情况,这个问题不适合我们的问答形式。我们希望答案得到事实、引用或专业知识的支持,但这个问题可能会引发辩论、争论、投票或扩展讨论。如果您觉得这个问题可以改进并可能重新打开,visitthehelpcenter指导。关闭9年前。我最近开始学习Ruby,这是我的第一门编程语言。我对语法感到满意,并且我已经完成了许多只教授相同基础知识的教程。我已经写了一些小程序(包括我自己的数组排序方法,在有人告诉我谷歌“冒泡排序”之前我认为它非常聪明),但我觉得我需要尝试更大更难的东西来理解更多关于Ruby.关于如何执行此操作的任何想法?

  10. ruby - rails 3.2.2(或 3.2.1)+ Postgresql 9.1.3 + Ubuntu 11.10 连接错误 - 2

    我正在使用PostgreSQL9.1.3(x86_64-pc-linux-gnu上的PostgreSQL9.1.3,由gcc-4.6.real(Ubuntu/Linaro4.6.1-9ubuntu3)4.6.1,64位编译)和在ubuntu11.10上运行3.2.2或3.2.1。现在,我可以使用以下命令连接PostgreSQLsupostgres输入密码我可以看到postgres=#我将以下详细信息放在我的config/database.yml中并执行“railsdb”,它工作正常。开发:adapter:postgresqlencoding:utf8reconnect:falsedat

随机推荐