首页 > 其他分享 >微服务架构基本原理学习笔记(一)

微服务架构基本原理学习笔记(一)

时间:2023-05-24 15:15:01浏览次数:55  
标签:服务 笔记 部署 基本原理 代码 单体 应用程序 架构

一、什么是微服务

  微服务是一种技术架构,通常我们可以把它理解为一组可以相互之间协同工作的应用程序或服务,这些应用程序或服务能够被单独部署到不同的服务器中,并且能够自主运行和维护。

  微服务技术只是一个名称而已,或许我们在日常工作中已经或多或少在使用其中的一种或几种技术和架构,但我们并没有将其称之为微服务。而且,对于微服务的大小和规模,也并没有严格的限制,也许几百行代码或者数个文件,也或者比这个规模更大一点,都没有关系。我们不应该在这一点上过多地纠结,而应该更多地去关心微服务到底解决了什么问题?这才是最主要的。

二、为什么需要微服务

  换句话说,微服务架构到底解决了什么问题?要回答这个问题,我们先对比一下单体架构(Monolith)与微服务架构(MicroService)。

单体架构

  在单体架构中,代码通常都放在一个代码库中,这就意味着所有的开发人员都必须基于同一个源代码库来工作。另外,单体架构的应用程序通常都运行在单一服务器或虚机中,并且数据被持久化到单个数据库。其优点是:

  1. 开发环境比较简单,所使用的技术栈统一。
  2. 所有的代码和资源都在同一个代码库中,容易查找和定位错误。
  3. 应用程序的部署和更新操作比较容易,我们只需要在一台服务器或虚机上替换掉旧的应用程序即可。

  单体架构有其自身的优点,如果你的应用程序符合这一定位并且运行良好,那么其实你完全没有必要使用微服务架构,或者说目前暂时还不需要。但是,当应用程序的规模不断增加时,问题就会逐渐被暴露出来。随着代码库变得越来越大,复杂性也会显著增加,其中积累的技术债也会越来越多,最终会导致代码变得难以维护,而且各个模块间的依赖关系也会非常复杂,往往一个小的功能调整也会涉及到许多代码的改动。

  另外一个问题就是单体应用程序的更新部署往往会导致服务的中断,从而影响到整个产品的用户体验和可用性。

  最后就是单体应用程序的功能扩展往往比较困难。当访问量增加时,我们除了增加服务器的配置和数量外(垂直扩展),无法简单地对程序进行横向扩展和功能扩充。这个时候你会发现,无论你采用何种技术栈,都无法摆脱单体架构本身所带来的这些问题,你所要考虑的是调整整个应用程序的架构,使其更符合敏捷开发模式的思维。

  有一点值得注意的是,我们需要将传统的分布式单体架构与微服务架构区别开来。

  所谓分布式单体架构,是指将组成应用程序的各个不同的模块或服务部署在不同的服务器或虚机中,它们都共享同一个中央数据库,彼此之间相互关联,形成一个紧耦合的结构。任何一个模块或服务的缺失都会导致整个应用程序无法正常工作。同时,这种结构也会给更新和部署带来挑战。

微服务架构

  在微服务架构中,我们将应用程序分解成足够小的部分,每一部分可以有自己独立的源代码库并且由不同的小型开发团队来进行开发和维护。就每一个微服务而言,其开发成本相对较低,随着项目的迭代,在必要的时候也可以丢弃某些微服务或者完全改写部分微服务。

  项目中的每一个微服务都可以自由选择所使用的技术和开发工具。你完全可以在其中一个微服务中使用关系型数据库,而在另一个微服务中使用文档型数据库。也可以在一个微服务中使用函数式编程语言(例如JavaScript或者Python),而在另一个微服务中使用面向对象编程语言(例如C#或Java)。每一个微服务的开发团队都可以自由选择最合适的技术。

  由于微服务之间是松耦合的,每一个微服务可以单独部署和运行,这样我们就可以实现整个应用程序的零宕机更新。而且如果有需要,每一个微服务也可以随时重新发布和更新,而不影响整个应用程序的运行。

  另外,根据需要我们也可以非常方便地对单个微服务进行扩展,从而将成本控制在最低。

  微服务架构的这些特性更加符合敏捷开发的原则,从而使得我们可以更快地适应不断变化的业务和需求。我想这也是为什么近年来微服务架构变得如此流行的原因之一。

  不过,在使用微服务架构之前,你需要首先了解下面这些你将要面对的挑战:

  1. 初始化并运行每个微服务,然后在整个应用程序的上下文中进行测试。由于每个微服务所使用的技术不同,运行的环境也千差万别,所以从下载源代码开始,你可能需要花费比较多的时间才能让这些微服务运行起来。考虑使用容器来自动完成所有这些预备步骤是一个不错的选择。
  2. 由于微服务之间的交互往往非常复杂,如果处理不当,你会很容易地陷入到多个微服务之间大量低效而冗长的通信陷阱中,这会导致整个应用程序性能低下。
  3. 虽然单个微服务的部署较为容易,但是当大量微服务同时工作时,手动部署和更新将变得更加低效和繁琐。因此,自动化部署将变得至关重要。
  4. 最后一点就是监控微服务的运行。我们当然不希望逐个地去检查每个微服务当前的运行状态,而是希望这些微服务能够自动报告它们的运行状况。因此,我们需要一种监控机制,能够让系统管理员在一个集中的地方查看所有微服务的运行日志和数据。

  不过,你不用太担心,有许多开源的软件和工具能够帮忙我们解决上述这些问题。

  Github上一个非常好的例子eShopOnContainers可以用来帮助我们学习和理解微服务架构。下面是这个项目的微服务架构图:

 

标签:服务,笔记,部署,基本原理,代码,单体,应用程序,架构
From: https://www.cnblogs.com/jaxu/p/17428316.html

相关文章

  • 01_MySQL基础架构
    01_MySQL基础架构MySQL45讲Note:课程专栏名称:《MySQL实战45讲》课程笔记参考:MYSQL45讲01_基础架构:一条SQL查询语句是如何执行的?一条SQL查询是如何执行的先看一下下面这个图​​我们首先理解一下Mysql的基础架构,理解如果执行一条简单的查询语句,Mysql进行了哪些操作。......
  • 基于大模型的优质Prompt开发课(3)--学习笔记ing
    在具体场景下优化Prompt常见应用场景与优化示例内容产业规模庞大、领域众多、大模型强大的生成能力给工作和生活带来了极大的想象力。01以营销场景中产品海报背景图生成为例,原始需求是画一张海岛旅游产品的营销海报背景【PromptV0.1】描述:任务+主体?看看这个结果有哪......
  • 【Kafka从入门到成神系列 一】Kafka基本概述和架构
    ......
  • DAY12笔记及补充
    今日未默写笔记要点:1.BOM定义及组成部分2.window对象3.history对象history.back等价于history.go(-1);history.forward等价于history.go(1)4.location对象<ahref="javascript:window.location.href='XX'">跳转到XX页面</a>5.document对象(1)document.getElementById定义:可......
  • 【技术】多端能力服务统一是一种关键的技术和架构
    ​多端能力服务统一是一种关键的技术和服务架构,旨在为不同终端设备提供一致的用户体验和功能。通过采用前端和后端技术的组合,如响应式Web设计、PWA、跨平台移动应用开发框架、RESTfulAPI、GraphQL、WebSocket、Serverless架构和微服务架构,可以实现多端能力服务统一的目标。......
  • 学习笔记-sql 篇
    groupbySELECTBIGINT(self_gds_id%10)item_group,CASEWHENBIGINT(self_gds_id%10)IN(0,3,4,5,6,9)THEN'人工定价'ELSE'算法定价'ENDtype--errorFROMjiuwu_sc.ads_spc_service_recycle_process_dsWHEREself_platform_on_shelf_time>......
  • 考古笔记3:通过L3交换机实现VLAN间通讯
    本主要介绍:在cisco中通过L3交换机实现VLAN间通讯。拓扑拓扑A:配置过程配置步骤1:sw2SW2#vlandataSW2(vlan)#vlan10VLAN10added:Name:VLAN0010SW2(vlan)#vlan20VLAN20added:Name:VLAN0020SW2(vlan)#applyAPPLYcompleted.SW2(vlan)#exitAPPLYcompleted.E......
  • 第一章Redis概述-动力节点最新Redis7笔记
    1Redis概述1.1Redis简介【动力节点】Redis入门到高级教程,全网最新最全redis缓存教程,redis百科大全Redis,Remote Dictionary Server,远程字典服务,是一个使用ANSIC语言编写、支持网络、可基于内存亦可持久化的日志型、NoSQL开源内存数据库,其提供多种语言的API。Redis之所以称......
  • Qt+QtWebApp开发笔记(三):http服务器动态html连接跳转基础交互
    前言  网页很多时候是动态的,于是本篇文章目标实现一个简答的动态页面—页静态页面互相跳转,点击可以跳转到子页面。 Demo  下载地址  链接:https://pan.baidu.com/s/1bbhcu1XTiaJRYGRQRG5a0g?pwd=1234 HTML基本页面交换  上一篇的“HelloWorld”......
  • TS语法笔记-1
    第一章快速入门0、TypeScript简介TypeScript是JavaScript的超集。它对JS进行了扩展,向JS中引入了类型的概念,并添加了许多新的特性。TS代码需要通过编译器编译为JS,然后再交由JS解析器执行。TS完全兼容JS,换言之,任何的JS代码都可以直接当成JS使用。相较于JS而言,TS拥有了静态类......