什么是微服务?

什么是微服务?你应该使用微服务吗?微服务与容器和 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. 基于容器微服务的PaaS云平台设计(二)通过kubernetes实现微服务容器管理

    版权声明:本文为博主原创文章,欢迎转载,转载请注明作者.原文超链接 ,博主地址:http://www.cnblogs.com/SuperXJ/ 上一章描述了基于spring cloud的微服务实例(实 ...

  2. Kong 微服务网关在 Kubernetes 的实践

    来源:分布式实验室译者:qianghaohao本文主要介绍将 Kong 微服务网关作为 Kubernetes (https://www.alauda.cn)集群统一入口的最佳实践,之前写过一篇文章使用 ...

  3. Docker+Kubernetes(k8s)微服务容器化实践

    第1章 初识微服务微服务的入门,我们从传统的单体架构入手,看看在什么样的环境和需求下一步步走到微服务的,然后再具体了解一下什么才是微服务,让大家对微服务的概念有深入的理解.然后我们一起画一个微服务的架 ...

  4. .Net Core 微服务容器系列基础目录篇

    1.开场白 HI,各位老铁,大家端午好,之前写了些关于.net core商城系列的文章,有点乱,今天心血来潮想着整理一下(今天只是先把目录列出来,后面的每篇文章这两天会进行重新修改的,目前先将就看下) ...

  5. .NET Core/.NET5/.NET6 开源项目汇总6:框架与架构设计(DDD、云原生/微服务/容器/DevOps/CICD等)项目

    系列目录     [已更新最新开发文章,点击查看详细] 开源项目是众多组织与个人分享的组件或项目,作者付出的心血我们是无法体会的,所以首先大家要心存感激.尊重.请严格遵守每个项目的开源协议后再使用.尊 ...

  6. .NET微服务 容器化.NET应用架构指南(支持.NET Core2)

    介绍 企业通过使用容器,日益实现成本节约.解决部署问题并改进 DevOps 和生产操作. 通过创建 Azure 容器服务.Azure Service Fabric 等产品,同时与 Docker.Mes ...

  7. 最热门的 10 个 Java 微服务框架

    1.Spring Boot Java 构建 Spring 应用程序已经有很长一段时间了,Spring Boot 是 Spring 的一个特定版本,它通过对配置细节的处理,使微服务构建更加简便.创建 S ...

  8. 微服务交付至kubernetes流程

    目录 1.微服务简介 2.K8s部署微服务考虑的问题 3.项目迁移到k8s流程 1.微服务简介 微服务优点 服务组件化 每个服务独立开发.部署,有效避免一个服务的修改引起整个系统重新部署 技术栈灵活 ...

  9. 十分钟搭建微服务框架(SpringBoot +Dubbo+Docker+Jenkins源码)

    本文将以原理+实战的方式,首先对“微服务”相关的概念进行知识点扫盲,然后开始手把手教你搭建这一整套的微服务系统. 这套微服务框架能干啥? 这套系统搭建完之后,那可就厉害了: 微服务架构 你的整个应用程 ...

随机推荐

  1. 谁知道百会CRM跟Zoho是一家公司吗?

    说到ZohoCRM,无论是搜索引擎还是信息网站,总会有无数的身影.很多人不知道这两家公司的关系,甚至认为百会和Zoho是一家公司.那么,百会CRM和Zoho属于同一类公司吗?它们之间有什么关系?今天小 ...

  2. Android系统“资源调度框架”

    Android系统"资源调度框架" 目录 Android系统"资源调度框架" 一.一些问题的思考 "资源"是什么 "资源" ...

  3. 笔记 BAT 面试题 及部分答案

    题目出自:https://www.jianshu.com/p/c70989bd5f29本文出自 AWeiLoveAndroid的博客 2018年2月20日星期二 随笔 笔记 BAT 面试题 一.jav ...

  4. 官宣.NET 6 预览版4

    我们很高兴发布 .NET 6 Preview 4.我们现在大约完成了 .NET 6 发布的一半.现在是一个很好的时机,可以再次查看.NET6的完整范围.许多功能都接近最终形式,而其他功能将很快推出,因 ...

  5. Mysql常用语句整理

    把工作常用的mysql命令整理一下,省的用的时候在到处找 1.常用命令 1.1 登录 mysql -u root -p 1.2 生成随机数 若在 i<=R<=j 范围内生成随机数 FLOO ...

  6. 「AGC023D」 Go Home

    「AGC023D」 Go Home 传送门 神题. 首先我们可以倒着考虑. 当车到达最后一栋楼的时候,车上一定只有到这栋楼的员工. 当车到达倒数第二栋楼的时候,车上一定只有到达剩下两栋楼的员工. 设这 ...

  7. java001-java基础

    基础数据类型 int--->Integer long--->Long float--->Float double--->Double boolean--->Boolean ...

  8. 【LeetCode】523. 连续的子数组和

    523. 连续的子数组和 知识点:数组:前缀和: 题目描述 给你一个整数数组 nums 和一个整数 k ,编写一个函数来判断该数组是否含有同时满足下述条件的连续子数组: 子数组大小 至少为 2 ,且 ...

  9. Vue中Object和Array数据变化侦测原理

    在学完Vue.js框架,完成了一个SPA项目后,一直想抽时间找本讲解Vue.js内部实现原理的书来看看,经过多方打听之后,我最后选择了<深入浅出Vue.js>这本书.然而惭愧的是,这本书已 ...

  10. [考试总结]noip模拟10

    不小心有咕掉了一段时间 这次考试咕掉的分数也是太多了 然后就是这次暴力完全没有打满 遗憾啊遗憾 T1 入阵曲 前面的题目背景故意引导我们去往矩阵快速幂的方向去想 然而半毛钱关系没有 其实就是维护前缀和 ...