微服务网关Zuul在EDAS环境的实践

本文涉及的产品
注册配置 MSE Nacos/ZooKeeper,118元/月
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
云原生网关 MSE Higress,422元/月
简介:

问题起因

最近参与的一个项目,客户基于EDAS开发的微服务应用,应用间提供的都是Restful接口。

总所周知,EDAS是基于内部HSF接口的分布式服务框架,HSF的特点是服务调用者和服务提供者直接连接,不经过网关层转发,HSF接口无需引入网关层,EDAS会承担服务注册与服务发现功能,服务调用时由HSF-Client根据从configserver推送过来的服务提供方ip,直接发起调用。

但是后端的微服务应用提供Restful接口的话,不可能把每一个微服务所提供的Restful接口都直接暴露给前端应用,这样的话,前端应用需要知道每个微服务的vip、端口、请求path,这么做并不友好。这里需要引入一个网关层,前端应用发起请求到网关,由网关根据请求url智能转发到后端不同的微服务应用处理。

调研过程

调研了相关的产品,有几个备选方案:
1)Nginx:通过配置upstream来实现请求转发;
2)CSB:云服务总线
3)Zuul:Springcloud的网关产品,但是不确定是否能适配EDAS环境

调研后发现:
1)Nginx,虽然可以通过配置upstream来实现请求转发,但是需要人工介入,每当上线或者调整微服务应用接口时,都需要手工修改配置文件,非常繁琐。
2)CSB:云服务总线CSB主要功能有两点,1是实现跨域的级联调用。2是协议转换。CSB并不支持路由转发。
3)Zuul:基于Springcloud体系的网关产品,非常符合客户想要的智能路由转发的功能,但是是否能适配EDAS是不确定的,翻了下官网EDAS的文档,也只提到了仅支持Springcloud的eureka服务注册功能,并没有涉及到Zuul。

检验

为了检验Zuul是否可以在EDAS环境正常使用,写了个Demo做了试验:
1)pom文件里引入Zuul,同时需要把springcloud原生的eureka包换成EDAS提供的vipclient包。
image.png

2)application.xml配置文件里加入Zuul转发规则:
image.png

3)启动后可以正常注册到EDAS轻量注册中心:
image.png

4)访问页面,能够实现智能转发:
image.png

结论

至此,经过验证后,发现Zuul网关是可以在EDAS环境里正常使用的。

相关实践学习
使用DAS实现数据库自动SQL优化
本场景介绍如何使用DAS实现数据库自动SQL优化。
SpringMVC框架入门
Spring MVC属于SpringFrameWork的后续产品,已经融合在Spring Web Flow里面。Spring 框架提供了构建 Web 应用程序的全功能 MVC 模块。在使用Spring进行WEB开发时,可以选择使用Spring的SpringMVC框架或集成其他MVC开发框架,如Struts2等。 相关的阿里云产品企业级分布式应用服务 EDAS:企业级分布式应用服务 EDAS(Enterprise Distributed Application Service)是一个应用托管和微服务管理的 PaaS 平台,提供应用开发、部署、监控、运维等全栈式解决方案,同时支持 Spring Cloud、Apache Dubbo(以下简称 Dubbo )等微服务运行环境,助力您的各类应用轻松上云。产品详情: https://www.aliyun.com/product/edas 
目录
相关文章
|
7天前
|
人工智能 API
阿里云微服务引擎及 API 网关 2024 年 6 月产品动态
阿里云微服务引擎及 API 网关 2024 年 6 月产品动态
103 14
|
21小时前
|
Kubernetes 监控 开发者
探索后端开发中的微服务架构实践
在现代软件开发领域,微服务架构作为一种灵活、可扩展的后端解决方案,正逐渐取代传统的单体式架构。本文将深入探讨微服务的设计理念、实施策略及其在企业级应用中的具体应用案例,旨在为读者提供一套系统的微服务实践指南。通过对比分析微服务与单体架构的性能差异,结合具体数据和案例研究,本文揭示了微服务在提高系统可维护性、可扩展性和敏捷性方面的优势。最后,文章讨论了微服务实施过程中可能遇到的挑战及解决策略,为后端开发者提供了宝贵的参考和启示。
|
5天前
|
监控 负载均衡 API
探索微服务架构下的API网关设计
【7月更文挑战第19天】在云原生时代,微服务架构以其灵活性和可扩展性成为企业数字化转型的优选。本文将深入探讨API网关在微服务架构中的核心角色,包括其设计原则、关键功能以及面临的挑战。我们将通过实例分析API网关如何提升系统的可维护性、安全性和性能,并讨论如何在复杂环境中实现高效的API管理策略。
82 9
|
2天前
|
监控 安全 前端开发
探索微服务架构中的API网关模式
【7月更文挑战第23天】在云原生时代,微服务架构已成为构建可扩展、灵活且容错的系统的标准方法。然而,随着服务的增多,如何有效地管理跨服务通信成为了一个挑战。API网关模式应运而生,作为微服务生态系统中的关键组件,它负责请求的路由、转发、过滤和加工处理。本文将从API网关的定义出发,深入探讨其在微服务架构中的应用,以及如何实现高效的服务治理。我们将通过实例分析来揭示API网关设计的最佳实践,并讨论其对系统性能、安全性和可维护性的影响。
|
3天前
|
弹性计算 负载均衡 监控
探索微服务架构下的API网关模式
在现代的分布式系统中,微服务架构已经成为了主流。随着服务的不断增多,如何高效地管理这些服务之间的通信成为了一个关键问题。本文将深入探讨API网关模式,一种有效的解决方案,它能够提供请求路由、负载均衡、认证授权和监控等功能。我们将通过对比分析、案例研究以及数据统计来展示API网关模式的优势,并讨论其在实际部署中的最佳实践和可能面临的挑战。
21 5
|
2天前
|
缓存 监控 负载均衡
探索微服务架构中的API网关模式
在微服务架构的海洋中,API网关如同一座灯塔,指引着服务间的通信。本文将深入探讨API网关的设计哲学、关键功能以及在实际应用中的考量因素。通过对比分析,我们将揭示API网关如何在提高系统可维护性、增强安全性和优化性能方面发挥其不可或缺的作用。此外,文章还将提供实践指南,帮助读者在构建或改进微服务架构时,做出明智的API网关选择和部署决策。
|
1天前
|
消息中间件 监控 Kubernetes
后端开发中的微服务架构实践与挑战
在数字化时代的浪潮下,后端开发不断演化,微服务架构应运而生,成为解决复杂系统设计问题的一种新范式。本文将深入探讨微服务架构的核心概念、实施策略以及面临的主要技术挑战,同时结合具体案例分析其在实际开发中的应用效果和价值体现,旨在为后端开发人员提供一套系统的微服务实践指南和思考框架。
|
2天前
|
负载均衡 监控 安全
探索微服务架构中的API网关模式
在微服务的大潮中,API网关扮演着至关重要的角色。它不仅是客户端与各个微服务之间的桥梁,更是性能优化、安全加固和协议转换的关键节点。本文将深入探讨API网关的核心概念,分析其在微服务架构中的重要性,并结合实例展示如何有效设计和管理API网关,以及如何通过网关解决跨域资源共享(CORS)和认证授权的挑战。
|
5天前
|
存储 设计模式 负载均衡
深入理解微服务架构中的API网关
在微服务架构的海洋中,API网关扮演着灯塔的角色,指引着服务的交互与集成。本文将探讨API网关的核心功能、设计考虑因素以及其在微服务生态系统中的重要性。通过具体案例分析,我们将揭示API网关如何优化服务发现、负载均衡和安全性等关键方面,并讨论其对系统性能的影响。
21 2
|
22小时前
|
负载均衡 监控 Cloud Native
探索微服务架构中的API网关模式
在微服务架构中,API网关扮演着至关重要的角色。它作为系统的单一入口点,不仅负责请求的路由、负载均衡和服务集成,还提供安全认证、监控和限流等关键功能。本文将深入探讨API网关的设计原则、实现策略及其在微服务生态系统中的作用,同时分析其在现代云原生应用中的实际运用案例。

热门文章

最新文章