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

简介: 带你读《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

 


 

 


 


相关文章
|
Dubbo Java 应用服务中间件
Spring Cloud Dubbo:微服务通信的高效解决方案
【10月更文挑战第15天】随着信息技术的发展,微服务架构成为企业应用开发的主流。Spring Cloud Dubbo结合了Dubbo的高性能RPC和Spring Cloud的生态系统,提供高效、稳定的微服务通信解决方案。它支持多种通信协议,具备服务注册与发现、负载均衡及容错机制,简化了服务调用的复杂性,使开发者能更专注于业务逻辑的实现。
417 2
|
Dubbo Java 应用服务中间件
💥Spring Cloud Dubbo火爆来袭!微服务通信的终极利器,你知道它有多强大吗?🔥
【8月更文挑战第29天】随着信息技术的发展,微服务架构成为企业应用开发的主流模式,而高效的微服务通信至关重要。Spring Cloud Dubbo通过整合Dubbo与Spring Cloud的优势,提供高性能RPC通信及丰富的生态支持,包括服务注册与发现、负载均衡和容错机制等,简化了服务调用管理并支持多种通信协议,提升了系统的可伸缩性和稳定性,成为微服务通信领域的优选方案。开发者仅需关注业务逻辑,而无需过多关心底层通信细节,使得Spring Cloud Dubbo在未来微服务开发中将更加受到青睐。
300 0
|
Dubbo 应用服务中间件 Apache
Star 4w+,Apache Dubbo 3.3 全新发布,Triple X 领衔,开启微服务通信新时代
在 Apache Dubbo 突破 4w Star 之际,Apache Dubbo 团队正式宣布,Dubbo 3.3 正式发布!作为全球领先的开源微服务框架,Dubbo 一直致力于为开发者提供高性能、可扩展且灵活的分布式服务解决方案。此次发布的 Dubbo 3.3,通过 Triple X 的全新升级,突破了以往局限,实现了对南北向与东西向流量的全面支持,并提升了对云原生架构的友好性。
524 112
|
负载均衡 Dubbo 应用服务中间件
框架巨擘:Dubbo如何一统异构微服务江湖,成为开发者的超级武器!
【8月更文挑战第8天】在软件开发中,微服务架构因灵活性和可扩展性备受欢迎。面对异构微服务的挑战,Apache Dubbo作为高性能Java RPC框架脱颖而出。它具备服务注册与发现、负载均衡及容错机制等核心特性,支持多种通信协议和序列化方式,能有效连接不同技术栈的微服务。Dubbo的插件化设计保证了面向未来的扩展性,使其成为构建稳定高效分布式系统的理想选择。
401 80
|
监控 负载均衡 API
Apache Apisix轻松打造亿级流量Api网关
Apache APISIX 是一个动态、实时、高性能的 API 网关,提供负载均衡、动态上行、灰度发布、熔断、鉴权、可观测等丰富的流量管理功能。适用于处理传统南北向流量、服务间东西向流量及 k8s 入口控制。Airflow 是一个可编程、调度和监控的工作流平台,基于有向无环图 (DAG) 定义和执行任务,提供丰富的命令行工具和 Web 管理界面,方便系统运维和管理。
Apache Apisix轻松打造亿级流量Api网关
|
Dubbo 应用服务中间件 Apache
Star 4w+,Apache Dubbo 3.3 全新发布,Triple X 领衔,开启微服务通信新时代
Star 4w+,Apache Dubbo 3.3 全新发布,Triple X 领衔,开启微服务通信新时代
244 0
|
Dubbo Cloud Native 应用服务中间件
阿里云的 Dubbo 和 Nacos 深度整合,提供了高效的服务注册与发现、配置管理等关键功能,简化了微服务治理,提升了系统的灵活性和可靠性。
在云原生时代,微服务架构成为主流。阿里云的 Dubbo 和 Nacos 深度整合,提供了高效的服务注册与发现、配置管理等关键功能,简化了微服务治理,提升了系统的灵活性和可靠性。示例代码展示了如何在项目中实现两者的整合,通过 Nacos 动态调整服务状态和配置,适应多变的业务需求。
598 2
|
存储 分布式计算 物联网
Apache IoTDB进行IoT相关开发实践
当今社会,物联网技术的发展带来了许多繁琐的挑战,尤其是在数据库管理系统领域,比如实时整合海量数据、处理流中的事件以及处理数据的安全性。例如,应用于智能城市的基于物联网的交通传感器可以实时生成大量的交通数据。据估计,未来5年,物联网设备的数量将达数万亿。物联网产生大量的数据,包括流数据、时间序列数据、RFID数据、传感数据等。要有效地管理这些数据,就需要使用数据库。数据库在充分处理物联网数据方面扮演着非常重要的角色。因此,适当的数据库与适当的平台同等重要。由于物联网在世界上不同的环境中运行,选择合适的数据库变得非常重要。 原创文字,IoTDB 社区可进行使用与传播 一、什么是IoTDB 我
650 9
Apache IoTDB进行IoT相关开发实践
|
Dubbo Java 应用服务中间件
Dubbo学习圣经:从入门到精通 Dubbo3.0 + SpringCloud Alibaba 微服务基础框架
尼恩团队的15大技术圣经,旨在帮助开发者系统化、体系化地掌握核心技术,提升技术实力,从而在面试和工作中脱颖而出。本文介绍了如何使用Dubbo3.0与Spring Cloud Gateway进行整合,解决传统Dubbo架构缺乏HTTP入口的问题,实现高性能的微服务网关。
|
存储 分布式计算 物联网
Apache IoTDB进行IoT相关开发实践
IoTDB是专为物联网(IoT)设计的开源时间序列数据库,提供数据收集、存储、管理和分析。它支持高效的数据写入、查询,适用于处理大规模物联网数据,包括流数据、时间序列等。IoTDB采用轻量级架构,可与Hadoop和Spark集成,支持多种存储策略,确保数据安全和高可用性。此外,它还具有InfluxDB协议适配器,允许无缝迁移和兼容InfluxDB的API和查询语法,简化物联网项目的数据管理。随着物联网设备数量的快速增长,选择适合的数据库如IoTDB对于数据管理和分析至关重要。
848 12

推荐镜像

更多