0
  • 聊天消息
  • 系统消息
  • 评论与回复
登录后你可以
  • 下载海量资料
  • 学习在线课程
  • 观看技术视频
  • 写文章/发帖/加入社区
创作中心

完善资料让更多小伙伴认识你,还能领取20积分哦,立即完善>

3天内不再提示

SOA/ESB架构升级之路:从微服务到ServiceMesh,再到Sermant

IT科技苏辞 来源: IT科技苏辞 作者: IT科技苏辞 2023-04-17 15:17 次阅读

SOA/ESB架构是一种常见的企业级应用架构模式,它将应用分为多个服务,通过ESB(企业服务总线)来进行服务间的通信和集成。SOA/ESB架构的优点是可以实现服务的复用、隔离和安全,但是也存在一些问题,如:

- ESB本身是一个单点故障,如果ESB出现问题,会影响所有的服务

- ESB的性能和可扩展性受限于其硬件和软件资源,如果服务数量和流量增加,ESB可能会成为瓶颈

- ESB的管理和维护成本较高,需要专业的团队来进行配置、监控和调优

- ESB的功能和协议可能不够灵活和标准化,导致服务间的耦合度较高

随着云计算和容器技术的发展,SOA/ESB架构模式在目前公有云上的典型参考架构是将应用部署在Kubernetes中,通过Ingress来暴露外部访问入口,通过Service来定义内部服务发现和负载均衡,通过ConfigMap和Secret来管理配置和敏感信息。这种架构模式相比于传统的SOA/ESB架构,有以下优势:

- Kubernetes提供了高可用、弹性伸缩、自愈等特性,可以保证应用的稳定性和可靠性

- Kubernetes支持多种云厂商和平台,可以实现应用的跨云部署和迁移

- Kubernetes提供了丰富的生态系统,可以集成各种开源或商业的工具和服务,如监控、日志、链路追踪等

然而,SOA/ESB架构虽然在隔离性、安全性上存在一定优点,但是短板也非常明显。首先,应用之间仍然需要通过ESB来进行通信和集成,这会增加网络延迟和复杂度,也会降低应用的自治性和灵活性。其次,ESB仍然是一个单点故障和性能瓶颈,如果ESB出现问题或者无法满足流量需求,会影响整个系统的可用性和效率。最后,ESB仍然需要专业的团队来进行管理和维护,这会增加运维成本和风险。

为了解决这些问题,许多企业开始尝试对SOA/ESB架构进行改造,从微服务到ServiceMesh,再到Sermant。

微服务是一种轻量级的服务架构模式,它将应用拆分为多个小而独立的服务,每个服务负责一个单一的业务功能,并且通过轻量级的协议(如HTTP、REST、gRPC等)来进行通信。微服务的优点是可以实现服务的高内聚、低耦合、快速迭代、独立部署等。但是微服务也带来了一些挑战,如:

- 服务数量增加导致管理复杂度增加

- 服务间通信需要处理网络不可靠、超时重试、负载均衡等问题

- 服务间需要实现统一的认证、授权、限流、熔断等功能

- 服务间需要实现跨服务的监控、日志、链路追踪等功能

为了解决这些挑战,ServiceMesh应运而生。ServiceMesh是一种基于代理模式的微服务架构,它将服务间的通信、治理、监控等功能从应用代码中剥离出来,交由一个独立的代理(如Envoy)来处理。ServiceMesh的优点是可以实现服务的自治性、灵活性、可观察性和安全性,同时降低了应用开发和运维的复杂度。但是ServiceMesh也存在一些问题,如:

- 引入了额外的代理,可能会增加网络延迟和资源消耗

- 需要对应用进行一定程度的改造,以适应ServiceMesh的通信和治理模式

- 需要学习和掌握新的技术和工具,如Istio、Linkerd等

Sermant是一种基于Java Agent的服务治理框架,它通过字节码增强技术来实现服务的动态注入和治理。Sermant的优点是可以在不改变应用代码的前提下,实现服务的注册发现、负载均衡、熔断降级、认证授权等功能,同时避免了ServiceMesh中代理带来的性能损耗。Sermant的核心思路如下:

1. 使用Java Agent来动态注入服务治理逻辑,无需修改应用代码

2. 采用AOP(面向切面编程)方式实现服务的拦截和增强,避免了sidecar模式的性能损耗

3. 提供灵活的配置和扩展机制,支持多种服务治理策略和插件

采用Sermant对SOA/ESB架构进行升级的步骤如下:

1. 准备工作:确认应用支持Sermant框架,安装Sermant Injector

2. 发布新版本的应用,携带Sermant Java Agent

3. 在配置中心,将应用加入白名单,实现灰度发布

4. 逐步将其他应用升级为携带Sermant Java Agent的版本,加入白名单

5. 删除应用的旧版本,完成升级

总之,SOA/ESB架构升级之路从微服务到ServiceMesh,再到Sermant,是一种逐步演进和优化的过程。通过采用Sermant框架,企业和组织可以更快速地实现云原生的微服务架构改造,提高业务运营效率和降低成本。同时,Sermant框架在性能、灵活性和易用性方面具有较大的优势,值得关注和尝试。

当前Sermant已在华为云云服务CSE中被集成,用户可以在华为云CSE云服务中使用相关功能。

审核编辑黄宇


声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
  • SOA
    SOA
    +关注

    关注

    1

    文章

    271

    浏览量

    27223
  • ESB
    ESB
    +关注

    关注

    0

    文章

    8

    浏览量

    8829
  • 华为云
    +关注

    关注

    3

    文章

    2155

    浏览量

    16807
收藏 人收藏

    评论

    相关推荐

    解析 Sermant 热插拔能力:服务运行时动态挂载 JavaAgent 和插件

    一、概述 Sermant 是基于 Java 字节码增强技术的无代理服务网格,其利用 Java 字节码增强技术,为宿主应用程序提供服务治理功能,以解决大规模微服务场景中的
    的头像 发表于 02-18 10:09 454次阅读
    解析 <b class='flag-5'>Sermant</b> 热插拔能力:<b class='flag-5'>服务</b>运行时动态挂载 JavaAgent 和插件

    游戏公司不使用微服务架构的原因

    微服务基本只有 request/response 的模式。做不了 streaming?微服务通常要求应用是无状态的才能做到水平扩展。streaming 本身就是加入了状态
    的头像 发表于 12-29 11:18 214次阅读

    如何搭建微服务架构的全局图景

    如果一直保持共用数据库的模式,则整个架构会越来越僵化,失去了微服务架构的意义。因此小明和小红一鼓作气,把数据库也拆分了。所有持久化层相互隔离,由各个服务自己负责。另外,为了提高系统的实
    的头像 发表于 12-27 15:16 247次阅读
    如何搭建<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>的全局图景

    如何构建弹性、高可用的微服务

    基于微服务的应用程序可实现战略性数字转型和云迁移计划,对于开发团队来说,这种架构十分重要。那么,如何来构建弹性、高可用的微服务呢?RedisEnterprise给出了一个完美的方案
    的头像 发表于 11-26 08:06 236次阅读
    如何构建弹性、高可用的<b class='flag-5'>微服务</b>?

    设计微服务架构的原则

    微服务是一种软件架构策略,有利于改善整体性能和可扩展性。你可能会想,我的团队需不需要采用微服务,设计微服务架构有哪些原则?本文会给你一些灵感
    的头像 发表于 11-26 08:05 235次阅读
    设计<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>的原则

    docker微服务架构实战

    随着云计算和容器化技术的快速发展,微服务架构在软件开发领域中变得越来越流行。微服务架构将一个大型的软件应用拆分成多个小型的、独立部署的服务
    的头像 发表于 11-23 09:26 313次阅读

    springcloud微服务架构

    Spring Cloud是一个开源的微服务架构框架,它提供了一系列工具和组件,用于构建和管理分布式系统中的微服务。它基于Spring框架,旨在通过简化开发过程和降低系统复杂性来帮助开发人员构建弹性
    的头像 发表于 11-23 09:24 386次阅读

    深入探讨微服务和事件驱动架构区别

    微服务不同,事件驱动架构不要求强制的粒度。事件处理器可以有不同的规模,可以是响应特定事件的小型功能,也可以是处理多个事件的大型子系统。在物流系统中,事件驱动架构可以包括用于包裹跟踪更新的小型事件处理器,也可以有更大的子系统用于
    的头像 发表于 10-30 15:06 261次阅读

    Spring Cloud :打造可扩展的微服务网关

    Spring Cloud Gateway是一个基于Spring Framework 5和Project Reactor的反应式编程模型的微服务网关。它提供了丰富的功能,包括动态路由、请求限流、集成安全性等,使其成为构建微服务架构
    的头像 发表于 10-22 10:03 259次阅读
    Spring Cloud :打造可扩展的<b class='flag-5'>微服务</b>网关

    SpringCloud微服务架构:实现分布式系统的无缝协作

    在深入Spring Cloud之前,让我们首先了解一下什么是微服务架构微服务架构是一种软件架构模式,将一个应用程序拆分为一组小型、独立的
    的头像 发表于 10-12 16:21 263次阅读
    SpringCloud<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>:实现分布式系统的无缝协作

    边缘计算微服务操作系统的设计与实现

    运行层、边缘计算微服务开发层,以及边缘计算微服务工业组件库,旨在提供微服务开发、集成、发布与共享为一体的敏捷式公共开发框架,提升工业微服务开发核心能力,强化工业物联及智能应用开发技术支
    的头像 发表于 08-31 16:49 608次阅读
    边缘计算<b class='flag-5'>微服务</b>操作系统的设计与实现

    【Spring Cloud 】基于微服务架构的智慧工地监管平台源码带APP

    技术架构微服务 开发语言:Java 开发工具:Idea 前端框架:Vue 后端框架:Spring Cloud 数 据 库:MySql 移 动 端:UniApp
    的头像 发表于 08-28 11:10 371次阅读
    【Spring Cloud 】基于<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>的智慧工地监管平台源码带APP

    基于SOA架构的整车操作系统的变革

    SOA全称为Service Oriented Architecture,即面向服务架构。1996年,SOA概念由Gartner提出,并率先在IT行业被应用推广。目前,
    发表于 08-11 11:31 362次阅读
    基于<b class='flag-5'>SOA</b><b class='flag-5'>架构</b>的整车操作系统的变革

    释放微服务架构全部潜力的关键

      释放微服务的力量 您是否正在努力构建高效、可扩展且有弹性的软件系统?作为软件开发人员或高级开发人员,您一定遇到过“微服务架构”一词。这种革命性的软件开发方法已被许多成功的科技巨头采用,例如
    的头像 发表于 06-25 11:54 329次阅读
    释放<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>全部潜力的关键

    从分层架构微服务架构介绍(五)

    本文要介绍的是 服务架构 (Service-Based Architecture, SBA )。 SBA 可以看成是单体架构微服务架构
    的头像 发表于 05-10 17:02 591次阅读
    从分层<b class='flag-5'>架构</b>到<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>介绍(五)