前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >搞懂微服务

搞懂微服务

作者头像
赵云龙龙
发布2022-04-26 20:28:12
4670
发布2022-04-26 20:28:12
举报
文章被收录于专栏:python爱好部落python爱好部落

首先服务提供者(用户、商品等微服务子模块)按照指定格式的服务接口描述,向注册中心注册服务,声明自己能够提供哪些服务以及服务的地址是什么,完成服务发布。

接下来服务消费者(API 网关层或者相邻的其它微服务模块)请求注册中心,查询所需要调用服务的地址,然后以约定的通信协议向服务提供者发起请求,得到请求结果后再按照约定的协议解析结果。

在服务调用过程中,服务的请求耗时、调用量以及成功率等指标都会被记录下来用作监控,调用经过的链路信息会被记录下来,用于故障定位和问题追踪。在这期间,如果调用失败,可以通过重试等服务治理手段来保证成功率。

所以总结起来,微服务架构下,服务调用主要依赖下面几个基本组件:

注册中心:

注册并维护远程服务及服务提供者的地址,供服务消费者发现和调用,为保证可用性,通常基于分布式 kv 存储器来实现,比如 zookeeper、etcd 等;

服务框架:

用于实现微服务的 RPC 框架,包含服务接口描述及实现方案、向注册中心发布服务等功能,常见的 RPC 框架包括 Spring Cloud、Dubbo、gRPC、 Thrift、go-micro 等;

服务网关:

介于客户端与微服务之间的网关层,可以理解为「门卫」的角色,以确保服务提供者对客户端的透明,这一层可以进行反向路由、安全认证、灰度发布、日志监控等前置动作;

服务监控:

对服务消费者与提供者之间的调用情况进行监控和数据展示;

服务追踪:

记录对每个请求的微服务调用完整链路,以便进行问题定位和故障分析;

服务治理:

服务治理就是通过一系列的手段来保证在各种意外情况下,服务调用仍然能够正常进行,这些手段包括熔断、隔离、限流、降级、负载均衡等。

基础设施:

分布式消息队列、日志存储、数据库、缓存、文件服务器、搜索集群等,用以提供服务底层的基础数据服务,可以自建,也可以使用阿里云等公有云提供的服务。 此外,从微服务部署角度来说,我们通常会基于容器编排技术实现微服务的运维。

众所周知,单体应用程序,由于其种种不足,几乎不支持敏捷方法。如果你想为一个大型或复杂的业务创建一个软件项目,最好从微服务架构开始。

微服务架构是一种灵活的架构,可以显著性地提高应用程序灵活性、可扩展性等。

基于微服务的架构通常有几个独立的单元,它们协同工作以接收和处理各种请求。这个复杂的某些部分可以是插件,这意味着在需要的情况下,你可以在不干扰应用程序的整体工作情况下, 新增一个新插件或删除一个插件。

例如,如果你决定实现一个微服务架构,你应该熟悉应用程序生命周期中的各种关注点,如持久化、日志记录、监控、负载均衡、缓存等,此外你还应该知道哪些哪些工具比较好或哪些堆栈更适合你的应用程序

w2.png

本文将会介绍微服务架构的关注点有: Docker 容器编排 Docker容器管理 API网关 负载均衡 服务发现 事件总线 日志记录 监控和警报 分布式追踪 数据持久化 缓存 云供应商

Docker

它是什么:

Docker 是一个开源平台,用于容器化你的应用程序,其中包含你的应用程序在各种环境中运行所需的类库和依赖项。在 Docker 的帮助下,开发团队能够将应用程序打包到容器中。

我为什么要使用它:

实际上,Docker 是容器化应用程序的哪些工具比较好之一,你也可以在不使用 Docker 的情况下创建容器,Docker 的真正好处是使这个过程更容易、更安全、更简单。

哪些工具比较好:Docker

容器编排

它是什么:

在容器化应用程序后,你将需要一些哪些工具比较好来管理容器化应用程序,以执行一些手动和自动操作,例如水平扩展。

我为什么要使用它:

这些哪些工具比较好为你的应用程序管理提供一些服务,例如自动负载均衡,保证服务的高可用性。

这种服务是通过定义多个管理器节点来完成的,如果一个节点管理器出现任何故障,其他管理器可以保持应用程序服务可用。

哪些工具比较好:

Kubernetes or K8s,Docker Swarm, harbor

Docker 容器管理

它是什么:

管理 Docker 环境、配置、安全等。

我为什么要使用它:

为用户提供了一个基于 GUI 的Docker 容器管理,可以使他们不必处理不舒服的 CLI。这些工具也为开发人员提供了丰富的 UI 来构建和发布他们的镜像,还可以通过提供简化的用户界面来更轻松地执行一些操作任务,例如服务水平扩展。

哪些工具比较好:

Portainer, DockStation, Kitematic,Rancher

API网关

它是什么:

API 网关可以被视为一种充当你的应用程序服务和不同客户端之间的中间件。API 网关可以管理许多事情,例如:

Routing :网关接收所有 API 请求并将它们转发到目标服务。

Logging :你将能够在一处记录所有请求。

Authorization: 检查你作为用户是否有资格访问该服务,如果没有,可以拒绝该请求

Performance profiling:你可以估计每个请求的执行时间并检查你的应用程序瓶颈。

Caching:通过在网关级别处理缓存,你将消除服务上的大量流量。

事实上,它是作为一个反向代理工作的,客户端只需要知道你的网关,应用服务就可以隐藏起来,不直接向其他系统暴露。

我为什么要使用它:

如果没有 API 网关,你可能需要在每个服务中做一些横切关注点,例如,如果你想记录服务的请求和响应。此外,如果你的应用程序由多个服务组成,你的客户端需要知道每个服务地址,并且在更改服务地址的情况下,应该更新多个地方。

哪些工具比较好:

Kong,Ocelot

负载均衡

它是什么:

我们选择微服务架构最重要的原因是可扩展性,这意味着我们将能够通过运行更多服务实例来处理更多请求,但问题是,哪个实例应该接收请求,或客户端如何知道哪个服务实例应该处理请求?

这些问题的答案是负载均衡。负载均衡是高可用网络基础架构的关键组件,通常用于将工作负载分布到多个服务器来提高网站、应用、数据库或其他服务的性能和可靠性。

我为什么要使用它:

为了扩展你的独立服务,你需要运行多个服务实例。使用负载均衡器,客户端不需要知道服务的正确实例。

哪些工具比较好:

Traefik , NGINX,Seesaw

服务发现

它是什么:

随着你的应用服务的数量越来越多,服务需要知道彼此的服务实例地址,但是在有很多服务的大型应用中,这是无法处理的。因此我们需要服务发现,它负责提供应用程序中所有组件的地址,它们可以轻松地向服务发现系统发送请求并获取可用的服务实例地址。

我为什么要使用它:

当你的应用程序中可以有多个服务时,服务发现对于你的应用程序来说是必不可少的。你的应用服务不需要知道每个服务实例地址,这意味着服务发现为你铺平了道路。

哪些工具比较好:

Consul,Zookeeper,Eureka,etcd和Keepalived

事件总线

它是什么:

在微服务架构模式中,你将使用两种不同类型的通信,同步通信以及异步通信。同步通信是指服务之间通过 HTTP 或 GRPC 相互调用。异步通信意味着服务通过消息总线或事件总线相互交互,这意味着服务之间没有直接连接。

你的架构可以同时使用两种通信方式,例如在在线商店示例中,你可以在订单注册时发送消息,并且订阅了特定频道的服务将收到该消息。但有时你可能需要一些实时的查询,例如,你需要知道一个物品的数量,你可能会在服务之间使用 GRPC 或 HTTP 调用来获取响应。

我为什么要使用它:

如果你想要一个包含多个服务的可扩展应用程序,你将遵循的原则之一是创建松散耦合的服务,这些服务通过事件总线相互交互。此外,如果你需要创建一个能够插入新服务以接收一系列特定消息的应用程序,则需要使用事件总线。

哪些工具比较好:

RabbitMQ,Kafka

日志记录

它是什么:

使用微服务架构模式时,最好将服务日志集中起来。这些日志将用于调试问题或根据其类型聚合日志以供分析使用。

我为什么要使用它:

系统调试时,如果没有提前集中在一个地方收集服务日志,你可能会遇到困难。你还可以将与特定请求相关的日志与唯一的相关 ID 关联。这意味着与请求相关的不同服务中的所有日志都可以通过此关联 ID 访问。

哪些工具比较好:

Elastic Logstash

监控和警报

它是什么:

在微服务架构中,如果你想要一个可靠的应用程序或服务,你必须监控应用程序的功能、性能、通信和任何其他方面,以实现一个负责任的应用程序。

我为什么要使用它:

你需要监控整体功能和服务健康状况,还需要监控性能瓶颈,并准备解决故障的计划。通过在关键点定义服务的早期警报来减少服务的停机时间,从而优化用户体验。当负载较重时等,可以监控服务的整体资源消耗。

哪些工具比较好:

Prometheus , Kibana,Grafana

分布式追踪

它是什么:

调试始终是开发人员最关心的问题之一,因为你都有跟踪或调试单体引用程序的经验。那是非常直接和容易,但是在微服务架构上,因为一个请求可能会通过不同的服务,这使得调试和跟踪变得困难,因为服务不在一个地方,所以分布式追踪工具将会有所帮助。

我为什么要使用它:

如果没有分布式跟踪哪些工具比较好,通过不同的服务跟踪你的请求会令人沮丧或不可能。你可以借助用于演示请求流的丰富 UI 轻松跟踪请求和事件。

哪些工具比较好:

OpenTelemetry , Jeager,Zipkin

数据持久化

它是什么:

在大多数系统中,我们需要持久化数据,将应用程序的数据写入具有不同结构的物理文件中,以便数据用于进一步的处理或报告。

我为什么要使用它:

在单体应用程序中,我们曾经有一种或两种不同的持久性类型,大多数单体应用程序使用关系数据库,如 SQL Server、Oracle、MySQL。但是在微服务架构中,我们应该遵循“DataBase Per Service”模式,这意味着保持每个微服务的持久数据对该服务是私有的,并且只能通过其 API 访问。

对于不同的用途和场景,你将拥有不同的数据库。例如,数据展示服务可能会使用像 ElasticSearch 或 MongoDB 这样的 NoSQL 数据库,因为它们使用文档基础结构,这意味着这些数据库中持久化数据的结构与关系数据库不同,更适用于具有读多写少的服务。

另一方面,在某些微服务中,你可能需要 Oracle 或 SQL SERVER 等关系数据库,或者你可能还需要一些支持图结构或键值结构的数据库。

所以,在微服务架构中,根据服务的使命,你会需要不同类型的数据库。

哪些工具比较好:

关系数据库或 RDBMS : PostgreSQL, MySQL, SQL Server, Oracle

NoSQL 数据库 : MongoDB, Cassandra,ElasticSearch

缓存

它是什么:

缓存减少了微服务架构的服务到服务通信的延迟。缓存是高速数据存储层。当从缓存中请求数据时,它的速度比访问硬盘中的数据要快。

我为什么要使用它:

在微服务架构中,有许多策略可以通过这些方式实现缓存。考虑以下:

1:嵌入式缓存(分布式和非分布式)

2:客户端-服务器缓存(分布式)

3:反向代理缓存(Sidecar)

为了减少延迟,可以在不同的层中实现缓存。此外,你还可以实现分布式缓存,它可以被多个微服务访问。它们还有不同的用途,比如限流,限流的目的是通过对并发访问/请求进行限速或者一个时间窗口内的的请求进行限速来保护系统,一旦达到限制速率则可以拒绝服务。

哪些工具比较好

Redis (Remote Dictionary Server), Apache Ignite,Hazelcast IMDG

云供应商

它是什么:

云服务提供商是一个第三方公司,提供基于云的平台,基础设施,应用程序或存储服务。就像房主为电力或天然气等公用事业付费一样,公司通常只需根据业务需求为他们使用的云服务数量付费。

云提供商最重要的类别:

软件即服务 (SaaS)。

平台即服务 (PaaS)。

基础设施即服务 (IaaS)。

我为什么要使用它 -

使用云计算服务的一个好处是,公司可以避免搭建和维护自己的 IT 基础设施的前期成本和复杂性,而只需在使用时为所用的东西付费。今天,公司可以租用从应用程序到存储的任何东西,而不是拥有自己的计算基础设施或数据中心。

哪些工具比较好:

Amazon Web Services (AWS), Microsoft Azure, Google Cloud,Alibaba Cloud

总结

在本文中,我试图展示一个与微服务架构模式相关的路线图。如果你想从头开始实现微服务架构或将单体架构迁移到微服务架构,你将需要了解这些概念。

除了这些概念之外,我们还有其他概念,如服务网格、缓存、持久性,它们可能是本路线图的一部分,但为了简单起见,我故意没有提及它们。

这些东西,如果要记住,怎么办,我总结了个顺口溜。 多编管网,均现总线,日奸追久存云。 记住《潜伏》里面的余则成,多编织管网,均出现了总线大鱼,原来是日奸名叫追究存云的家伙,拉出去枪毙,死啦死啦的。 我自己的联想记忆法,虽然糙,但是管用。

OK, 我们来看一个实际的例子: 所有服务注册到注册中心(认证服务,消息推送,搜索服务,短信服务,网关) 用户请求之前需要通过网关从注册中心获取认证服务地址,请求认证服务获取到token,网关将token存储至redis。 客户端获取token以后,携带token发起数据接口请求。 在网关接受客户端请求以后,通过注册中心获取到业务服务列表,从而转发数据请求到后台业务服务。 业务服务在接受网关请求时,校验token有效性,通过验证之后,业务接口返回数据至网关,最后返回到客户端,整个请求结束。

业务逻辑模块:

基础设施集群:数据库,缓存,搜索引擎,消息队列,实时推送,web引擎,文件存储/缓存,云计算,大数据 公共基础服务:认证中心,用户中心,短信/邮件,权限中心,搜索中心 业务逻辑服务:邮件系统,个人服务,聊天服务,新闻服务,博客,职位信息 前端:负载均衡,CDN,智能DNS

这些东西,在工作中慢慢理解,慢慢琢磨,总会有所收获。

本文参与 腾讯云自媒体分享计划,分享自微信公众号。
原始发表:2022-03-25,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 python粉丝团 微信公众号,前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 注册中心:
  • 服务框架:
  • 服务网关:
  • 服务监控:
  • 服务追踪:
  • 服务治理:
  • 基础设施:
  • Docker
  • 容器编排
  • Docker 容器管理
  • API网关
  • 负载均衡
  • 服务发现
  • 事件总线
  • 日志记录
  • 监控和警报
  • 分布式追踪
  • 数据持久化
  • 缓存
  • 云供应商
    • 我为什么要使用它 -
      • 总结
      相关产品与服务
      容器镜像服务
      容器镜像服务(Tencent Container Registry,TCR)为您提供安全独享、高性能的容器镜像托管分发服务。您可同时在全球多个地域创建独享实例,以实现容器镜像的就近拉取,降低拉取时间,节约带宽成本。TCR 提供细颗粒度的权限管理及访问控制,保障您的数据安全。
      领券
      问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档