带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(1)

本文涉及的产品
云原生网关 MSE Higress,422元/月
性能测试 PTS,5000VUM额度
Serverless 应用引擎免费试用套餐包,4320000 CU,有效期3个月
简介: 带你读《Apache Dubbo微服务开发从入门到精通》——三、 网关(1)


三、 网关

 

1. Apache APISIX

 

1) 背景

 

Apache Dubbo是由阿里巴巴开源并捐赠给Apache的微服务开发框架,它提供了RPC通信与微服务治理两大关键能力。不仅经过了阿里电商场景中海量流量的验证,也在国内的技术公司中被广泛落地。

 

在实际应用场景中,Apache Dubbo一般会作为后端系统间RPC调用的实现框架,当需要提供HTTP接口给到前端时,会通过一个「胶水层」将Dubbo Service包装成HTTP接口,再交付到前端系统。

 

Apache APISIX是Apache软件基金会的顶级开源项目,也是当前最活跃的开源网关项目。作为一个动态、实时、高性能的开源API网关,Apache APISIX提供了负载均衡、动态上游、灰度发布、服务熔断、身份认证、可观测性等丰富的流量管理功能。

 

得益于Apache Dubbo的应用场景优势,Apache APISIX基于开源项目tengine/mod_dubbo模块为Apache Dubbo服务配备了HTTP网关能力。通过dubbo-proxy插件,可以轻松地将Dubbo Service发布为HTTP服务。

 

image.png

 

2) 如何使用

 

a) 入门篇:安装使用

 

注:

这里我们建议使用 Apache APISIX 2.11版本镜像进行安装。该版本的APISIX-Base中已默认编译了Dubbo模块,可直接使用dubbo-proxy插件。

 

在接下来的操作中,我们将使用dubbo-samples项目进行部分展示。该项目是一些使用Apache Dubbo实现的Demo应用,本文中我们采用其中的一个子模块作为Dubbo Provider。

 

在进入正式操作前,我们先简单看下Dubbo接口的定义、配置以及相关实现。

 

接口实现一览

 

image.png

 

如上所示,Dubbo接口的定义是固定的。即方法参数中Map表示APISIX传递给Dubbo Provider关于HTTP request的一些信息(如:header、body...)。而方法返回值的Map表示Dubbo Provider传递给APISIX要如何返回HTTP response的一些信息。

 

接口信息配置好之后可通过XML配置方式发布DemoService。

 

image.png

 

通过上述配置后,Consumer可通过org.apache.dubbo.samples.apisix.DemoService访问其中的apisixDubbo方法。具体接口实现如下:

 

image.png

 

上述代码中,DemoServiceImpl会打印接收到的httpRequestContext,并通过返回包含有指定Key的Map对象去描述该Dubbo请求的HTTP响应。

 

操作步骤

 

启动dubbo-samples。

在config.yaml文件中进行dubbo-proxy插件启用。

 

image.png

 

创建指向Dubbo Provider的Upstream。

 

image.png

 

为DemoService暴露一个HTTP路由。

 

image.png

 

使用curl命令请求Apache APISIX,并查看返回结果。

 

image.png

 

注:

上述代码返回中包含了test123 Header,以及dubbo success字符串作为Body体。这与我们在DemoServiceImpl编码的预期效果一致。

 

查看Dubbo Provider的日志。

 

image.png

 

注:

通过httpRequestContext可以拿到HTTP请求的Header和Body。其中Header会作为Map元素,而Body中Key值是固定的字符串“body”,Value则代表Byte数组。

 


 《Apache Dubbo微服务开发从入门到精通》——服务治理与生态——三、 网关(2) :https://developer.aliyun.com/article/1223992

 


 

 


 


相关文章
|
2月前
|
Cloud Native API
微服务引擎 MSE 及云原生 API 网关 2024 年 9 月产品动态
微服务引擎 MSE 及云原生 API 网关 2024 年 9 月产品动态。
|
2月前
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
74 2
|
2月前
|
缓存 监控 API
探索微服务架构中的API网关模式
【10月更文挑战第5天】随着微服务架构的兴起,企业纷纷采用这一模式构建复杂应用。在这种架构下,应用被拆分成若干小型、独立的服务,每个服务围绕特定业务功能构建并通过HTTP协议协作。随着服务数量增加,统一管理这些服务间的交互变得至关重要。API网关作为微服务架构的关键组件,承担起路由请求、聚合数据、处理认证与授权等功能。本文通过一个在线零售平台的具体案例,探讨API网关的优势及其实现细节,展示其在简化客户端集成、提升安全性和性能方面的关键作用。
78 2
|
2月前
|
存储 缓存 监控
探索微服务架构中的API网关模式
【10月更文挑战第1天】探索微服务架构中的API网关模式
98 2
|
7天前
|
NoSQL 前端开发 测试技术
👀探秘微服务:从零开启网关 SSO 服务搭建之旅
单点登录(Single Sign-On,简称SSO)是一种认证机制,它允许用户只需一次登录就可以访问多个应用程序或系统。本文结合网关和SaToken快速搭建可用的Session管理服务。
46 8
|
16天前
|
Cloud Native API 微服务
微服务引擎 MSE 及云原生 API 网关 2024 年 11 月产品动态
微服务引擎 MSE 及云原生 API 网关 2024 年 11 月产品动态。
|
17天前
|
运维 Cloud Native 应用服务中间件
阿里云微服务引擎 MSE 及 云原生 API 网关 2024 年 11 月产品动态
阿里云微服务引擎 MSE 面向业界主流开源微服务项目, 提供注册配置中心和分布式协调(原生支持 Nacos/ZooKeeper/Eureka )、云原生网关(原生支持Higress/Nginx/Envoy,遵循Ingress标准)、微服务治理(原生支持 Spring Cloud/Dubbo/Sentinel,遵循 OpenSergo 服务治理规范)能力。API 网关 (API Gateway),提供 APl 托管服务,覆盖设计、开发、测试、发布、售卖、运维监测、安全管控、下线等 API 生命周期阶段。帮助您快速构建以 API 为核心的系统架构.满足新技术引入、系统集成、业务中台等诸多场景需要
|
22天前
|
设计模式 负载均衡 监控
探索微服务架构下的API网关设计
在微服务的大潮中,API网关如同一座桥梁,连接着服务的提供者与消费者。本文将深入探讨API网关的核心功能、设计原则及实现策略,旨在为读者揭示如何构建一个高效、可靠的API网关。通过分析API网关在微服务架构中的作用和挑战,我们将了解到,一个优秀的API网关不仅要处理服务路由、负载均衡、认证授权等基础问题,还需考虑如何提升系统的可扩展性、安全性和可维护性。文章最后将提供实用的代码示例,帮助读者更好地理解和应用API网关的设计概念。
51 8
|
1月前
|
负载均衡 监控 API
dotnet微服务之API网关Ocelot
Ocelot 是一个基于 .NET 的 API 网关,适用于微服务架构。本文介绍了如何创建一个 Web API 项目并使用 Ocelot 进行 API 请求路由、负载均衡等。通过配置 `ocelot.json` 和修改 `Program.cs`,实现对 `GoodApi` 和 `OrderApi` 两个项目的路由管理。最终,通过访问 `https://localhost:7122/good/Hello` 和 `https://localhost:7122/order/Hello` 验证配置成功。
34 1
dotnet微服务之API网关Ocelot
|
1月前
|
Dubbo Cloud Native 应用服务中间件
阿里云的 Dubbo 和 Nacos 深度整合,提供了高效的服务注册与发现、配置管理等关键功能,简化了微服务治理,提升了系统的灵活性和可靠性。
在云原生时代,微服务架构成为主流。阿里云的 Dubbo 和 Nacos 深度整合,提供了高效的服务注册与发现、配置管理等关键功能,简化了微服务治理,提升了系统的灵活性和可靠性。示例代码展示了如何在项目中实现两者的整合,通过 Nacos 动态调整服务状态和配置,适应多变的业务需求。
40 2

热门文章

最新文章

推荐镜像

更多