Dubbo-go-pixiu 是一款高性能 API 网关,支持 Dubbo 和 Http 等多种协议。具体介绍文章可以参考《Dubbo 跨语言调用神兽:dubbo-go-pixiu》

近期社区发布了 0.4.0 版本,具体请查看 v0.4.0。相关改进实在太多,本文只列出相关重大 feature、bugfix 、 性能提升项。

1 动态从 Spring Cloud 和 Dubbo 注册中心拉取路由和集群配置数据

Pixiu 原本依赖本地配置文件读取路由和 upstream 集群配置数据,对于真实生产场景十分不方便。因此,Pixiu 需要支持从集群注册中心动态获取路由和集群配置数据的功能。

如上图所示,服务A、B、C 进行服务注册,将自身元数据存储在注册中心。而 Pixiu 则从注册中心拉取注册的服务元数据,构建自己的路由规则和转发集群配置。当客户端发送请求时,Pixiu 会基于构建的转发规则,将请求转发给对应的后端服务。

社区同学分别就目前主流的两大微服务解决方案 Spring Cloud 和 Dubbo 进行了相关特性开发,相关的 pr 为 https://github.com/apache/dubbo-go-pixiu/pull/255https://github.com/apache/dubbo-go-pixiu/pull/256

目前,该特性只支持从 zk 和 nacos 拉取元数据,更多服务注册中心的支持工作正在进行中,欢迎感兴趣的同学参与,可以加入钉钉群 31203920。

2 支持 Http 协议 转换为 gRPC 协议

gRPC 协议已经是事实上的云原生基础通信协议。etcd、istio、dapr 等大量云原生中间件都提供 gRPC 相关的 API 接口供外界使用,dubbogo 3.0 也是基于 gRPC 构建了完全兼容 gRPC 的 triple协议。

但是对于外部系统而言,传统 HTTP 请求仍然是最为简单和稳定的通信手段,所以 Pixiu 提供了 Http 协议请求转换为 gRPC 协议请求的能力,方便将内部服务的 gRPC API 以 Http 的形式进行对外暴露。具体模式如下图所示,Pixiu 负责将客户端的 Http 请求进行解码,然后编码为 gRPC 请求,并转发给后端服务。

目前 Pixiu 是基于本地配置的 proto 文件进行相关协议的编解码工作的,具体pr 为 https://github.com/apache/dubbo-go-pixiu/pull/244。下一阶段将通过 gRPC 的反射能力,来动态获取 proto 配置信息,减少网关处的配置工作。

3 支持 jaeger 规范的链路传播协议

可观测性是大型软件系统的重要质量指标之一,而分布式链路追踪是其中的重中之重。

Pixiu 基于 opentelemetry 规范构建了分布式链路追踪体系,并支持将数据上传到 jaeger 上进行记录和展示。Pixiu 还会将 Span 相关信息向 upstream 服务传递,由此开发者可以看到每一个经过 Pixiu 进行转发的网络请求的完整处理链路,方便用户进行链路追踪和排查线上问题。

OpenTelemetry 合并了 OpenTracing 和 OpenCensus 项目,提供了一组 API 和库来标准化遥测数据的采集和传输,使用该规范可用方便的在不同分布式链路追踪数据存储端进行切换。目前 Pixiu 支持将数据上传到 jaeger 上,后续可以进行扩展,支持不同种类的 TracerProvider。

使用 Jaeger 进行追踪的效果图如下所示。

具体的 pr 是 https://github.com/apache/dubbo-go-pixiu/pull/236

4 支持 cors 策略

Pixiu 支持跨域资源共享策略,具体的 pr 是 https://github.com/apache/dubbo-go-pixiu/pull/249

5 支持 HTTPS 安全加密

Pixiu 支持 HTTPS 安全加密,具体的 pr 是 https://github.com/apache/dubbo-go-pixiu/pull/213

6 添加了更多的案例项目

Pixiu 项目的 samples 文件夹下添加了更多案例项目,包括并不限于:

spring cloud 和 Dubbo 集群的服务发现案例,路径是 samples/springcloud 和 samples/dubbogo/simple/registry;

分布式链路追踪案例,路径是samples/dubbo/simple/jaeger;

http to grpc 案例,路径是 samples/http/grpc/。

7 docker 示例

目前 Pixiu 社区开发了一个 docker 镜像,方便你进行测试,当前支持dubbo服务的zookeeper和nacos注册中心,配置指定环境变量的注册中心(你自己的dubbo服务注册中心地址)地址即可使用:

docker pull phial3/dubbo-go-pixiu:0.0.1
docker run --name you-pixiu-name -e DUBBO_REGISTRY_ADDRESS=zookeeper://10.170.224.25:2181 phial3/dubbo-go-pixiu:0.0.1
docker run --name you-pixiu-name -e DUBBO_REGISTRY_ADDRESS=nacos://10.170.224.25:8848 phial3/dubbo-go-pixiu:0.0.1

如果你有任何疑问,欢迎加入 dubbogo社区群【钉钉搜索群号 23331795 或者 钉钉扫码如下群二维码】

作者:张天,山东人,2018 年从南京大学毕业。目前就职于南京本地一家创业公司。

What's new in dubbo-go-pixiu 0.4.0的更多相关文章

  1. Nacos发布0.5.0版本,轻松玩转动态 DNS 服务

    阿里巴巴微服务开源项目Nacos于近期发布v0.5.0版本,该版本主要包括了DNS-basedService Discovery,对Java 11的支持,持续优化Nacos产品用户体验,更深度的与Sp ...

  2. Nacos Committers 团队首亮相,发布 0.9.0 版本

    223 天,发布 14 个版本,19 位 Committers,39 位 Contributors. 在宣布开源后的第 223 天,Nacos 发布了其第14个版本 - 0.9.0,该版本提升了 Na ...

  3. 微软Visual Studio Code 0.8.0发布,新增多种主题

    月30日,Build 开发者大会上,正式宣布了 Visual Studio Code 项目;并将其定义为:一个运行于 Mac OS X.Windows和 Linux 之上的,针对于编写现代 Web 和 ...

  4. Ubuntu14.04 64位机上安装cuda8.0 cudnn5.0操作步骤 - 网络资源是无限的

    查看Ubuntu14.04 64位上显卡信息,执行: lspci | grep -i vga lspci -v -s 01:00.0 nvidia-smi 第一条此命令可以显示一些显卡的相关信息:如果 ...

  5. Xamarin For Visual Studio 3.0.54.0 完整离线破解版(C# 开发Android、IOS工具 吾乐吧软件站分享)

    Xamarin For Visual Studio就是原本的Xamarin For Android 以及 Xamarin For iOS,最新版的已经把两个独立的插件合并为一个exe安装包了.为了区分 ...

  6. 《征服 C 指针》摘录1:什么是空指针?区分 NULL、0 和 '\0'

    一.什么是空指针? 空指针 是一个特殊的指针值. 空指针 是指可以确保没有向任何一个对象的指针.通常使用宏定义 NULL 来表示空指针常量值. 空指针 确保它和任何非空指针进行比较都不会相等,因此经常 ...

  7. Oracle Database 11g Release 2(11.2.0.3.0) RAC On Redhat Linux 5.8 Using Vmware Workstation 9.0

    一,简介 二,配置虚拟机 1,创建虚拟机 (1)添加三块儿网卡:   主节点 二节点 eth0:    公网  192.168.1.20/24   NAT eth0:    公网  192.168.1 ...

  8. kafka0.9.0及0.10.0配置属性

    问题导读1.borker包含哪些属性?2.Producer包含哪些属性?3.Consumer如何配置?borker(0.9.0及0.10.0)配置Kafka日志本身是由多个日志段组成(log segm ...

  9. Missing artifact com.oracle:ojdbc14:jar:10.2.0.4.0

    下载jar,导入到maven中cmd中输入:mvn install:install-file -DgroupId=com.oracle -DartifactId=ojdbc14 -Dversion=1 ...

随机推荐

  1. JAVA序列化浅析

    java.io.Serializable浅析 Java API中java.io.Serializable接口源码: 1 public interface Serializable { 2 } 类通过实 ...

  2. Can a C++ class have an object of self type?

    A class declaration can contain static object of self type,it can also have pointer to self type,but ...

  3. Spring DM 2.0 环境配置 解决Log4j问题

    搭建 spring dm 2.0 环境出的问题 log4j 的问题解决办法是 一.引入SpringDM2.0的Bundle,最后完成如下图所示:注意:要引入slf4j.api.slf4j.log4j. ...

  4. 【Linux】【Services】【SaaS】Docker+kubernetes(1. 基础概念与架构图)

    1.简介 1.1.  背景:公司正在进行敏捷开发环境的搭建,以取代传统的架构,好处大大的,我就不赘述了.公司原来负责这个项目的同事要转组,我只好交给另外同事继续,但是为了防止同样的事情,我也需要深入了 ...

  5. 【HarmonyOS】【xml】使用xml绘制视频播放控制栏

    本文记录HarmonyOS使用xml绘制视频播放控制栏 效果图如下 代码如下 点击查看代码 <?xml version="1.0" encoding="utf-8& ...

  6. java多线程5:线程间的通信

    在多线程系统中,彼此之间的通信协作非常重要,下面来聊聊线程间通信的几种方式. wait/notify 想像一个场景,A.B两个线程操作一个共享List对象,A对List进行add操作,B线程等待Lis ...

  7. 推荐2个Mac OS X上的JSON工具

    原文:http://www.giser.net/?p=887 1 visual JSON 能够将JSON串以列表的方式展示,方便对JSON数据的解析. 2 JSONModeler 可以解析JSON串生 ...

  8. 减轻内存负担,在 pymysql 中使用 SSCursor 查询结果集较大的 SQL

    前言 默认情况下,使用 pymysql 查询数据使用的游标类是 Cursor,比如: import pymysql.cursors # 连接数据库 connection = pymysql.conne ...

  9. Python语法之基本数据类型

    一.数据类型之字符串str 作用:主要用于记录描述性性质的数据,如姓名.地址.邮箱: 定义: 方式1 # 单引号 name = 'jason' 方式2 # 双引号 name = "jason ...

  10. java File 类对操作系统文件目录进行操作:增删查

    File类 1,概述 File类是java.io包下代表与平台无关的文件和目录,也就是说,如果希望在程序中操作文件和目录,都可以通过File类来完成. 2,构造方法 public File(Strin ...