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

    文章

    319

    浏览量

    29030
  • ESB
    ESB
    +关注

    关注

    0

    文章

    10

    浏览量

    9040
  • 华为云
    +关注

    关注

    3

    文章

    2804

    浏览量

    19090
收藏 人收藏
加入交流群
微信小助手二维码

扫码添加小助手

加入工程师交流群

    评论

    相关推荐
    热点推荐

    ESB 故障排查的核心痛点

    收:ESB 已成功发出消息,但接收方未收到(如接收方服务离线、端口未监听)或未返回确认。 二、除 ACK 外的核心判断依据 ESB 本地日志:记录消息发送状态(如 “发送中”“发送失败”“已投递至接收方节点
    发表于 11-17 15:43

    华纳云VPS容器服务网格流量管理:实现微服务高效路由

    网格技术优化香港VPS的流量管理,东西向流量控制金丝雀发布实施,全方位解析提升服务稳定性与安全性的核心策略。无论您是运维工程师还是架构师,这些实战经验都将帮助您在跨境业务部署中实现
    的头像 发表于 10-16 17:09 380次阅读

    Jtti海外VPS微服务架构下的日志采集与分析优化方案

    随着跨境业务和分布式应用的普及,越来越多的企业在海外VPS上构建微服务架构,以提升系统扩展性和灵活性。然而,微服务化带来了一个新的挑战:日志数据分散在多个服务和节点中,若缺乏统一采集与
    的头像 发表于 08-27 17:13 420次阅读

    电商API的微服务架构优化策略

    ​ 随着电子商务的快速发展,API(应用程序编程接口)已成为电商平台的核心组件,负责连接用户、商家和后台系统。微服务架构通过将应用拆分为独立、可扩展的服务单元,显著提升了系统的灵活性和可维护性。然而
    的头像 发表于 07-23 14:30 396次阅读
    电商API的<b class='flag-5'>微服务</b><b class='flag-5'>架构</b>优化策略

    OptiSystem应用:宽带SOA特性

    )信号增益和(b)SOA输出处的ASE总功率变化曲线 在第二部分中,注入电流参数30 mA150 mA变化。输入信号功率保持在- 30dbm。 图3为仿真得到的信号增益结果。 图3.信号增益随注入
    发表于 06-10 08:45

    OptiSystem应用:宽带SOA特性

    )信号增益和(b)SOA输出处的ASE总功率变化曲线 在第二部分中,注入电流参数30 mA150 mA变化。输入信号功率保持在- 30dbm。 图3为仿真得到的信号增益结果。 图3.信号增益随注入
    发表于 05-19 08:48

    SOA架构开发小助手PAVELINK.SOA-Converter 2.1.2新版本发布

    为提升汽车SOA架构设计开发效率,优化用户体验,我们对PAVELINK.SOA-Converter进行了全新升级。本次2.1.2新版本升级
    的头像 发表于 04-09 10:37 1250次阅读
    <b class='flag-5'>SOA</b><b class='flag-5'>架构</b>开发小助手PAVELINK.<b class='flag-5'>SOA</b>-Converter 2.1.2新版本发布

    ESB 协议有什么优点呢?

    Enhanced ShockBurst (ESB)协议具有以下优点: 低功耗通信 - ESB提供低功耗的无线通信,这对于电池供电的IoT设备尤为重要。ESB用户指南指出:“ESB pr
    的头像 发表于 03-24 14:50 639次阅读

    微服务架构几种典型的基础框架,你了解吗?

    SpringCloud、Dubbo、Dropwizard、Akka等是常见微服务框架。SpringCloud基于SpringBoot,生态丰富;Dropwizard轻量且继承SpringBoot优点
    的头像 发表于 03-04 11:05 790次阅读

    微服务容器化部署好处多吗?

    微服务容器化部署好处有很多,包括环境一致性、资源高效利用、快速部署与启动、隔离性与安全性、版本控制与回滚以及持续集成与持续部署。这些优势助力应用可靠稳定运行,提升开发运维效率,是现代软件架构的优质选择。UU云小编认为微服务容器化
    的头像 发表于 01-17 10:22 544次阅读

    容器化能替代微服务吗?两者有何区别

    和可维护性。而容器化技术则是一种轻量级的虚拟化技术,它将应用程序及其依赖项打包一个独立的容器中,使其能够在不同的环境中一致地运行。虽然容器化技术为微服务提供了一个理想的运行环境,但微服务架构
    的头像 发表于 01-13 10:40 687次阅读

    基于SOA自动驾驶整车及运营系统架构

    随着车辆智能化、信息化、电动化和服务化的不断深入,车辆电子电气架构开发模式遇到了巨大的挑战,经纬恒润通过多年的技术积累和研发实践,运用面向服务架构(Service Oriented
    的头像 发表于 01-06 17:00 1293次阅读
    基于<b class='flag-5'>SOA</b>自动驾驶整车及运营系统<b class='flag-5'>架构</b>

    基于SOA自动驾驶整车及运营系统架构

    随着车辆智能化、信息化、电动化和服务化的不断深入经纬恒润通过多年的技术积累和研发实践,运用面向服务架构(Service Oriented Architecture,SOA)设计思想和
    的头像 发表于 01-06 16:06 27次阅读
    基于<b class='flag-5'>SOA</b>自动驾驶整车及运营系统<b class='flag-5'>架构</b>

    宝藏级微服务架构工具合集

    宝藏级热门微服务架构工具包含Spring Boot、Eclipse Vert.X、Kubernetes、Tyk、RabbitMQ、Apache Kafka等。其中,Spring Boot简化了微服务
    的头像 发表于 12-21 16:33 902次阅读

    面向服务的整车EE架构SOA)设计开发咨询服务

    经纬恒润多年来一直致力于为客户提供先进电子电气架构解决方案,近年来,经纬恒润在国内率先开展整车SOA架构的技术研发和业务布局,参与多款SOA架构
    的头像 发表于 12-12 15:11 1254次阅读
    面向<b class='flag-5'>服务</b>的整车EE<b class='flag-5'>架构</b>(<b class='flag-5'>SOA</b>)设计开发咨询<b class='flag-5'>服务</b>