SOFAMesh中的Dubbo on x-protocol

注意:本书中的 Service Mesh 章节已不再维护,请转到 istio-handbookarrow-up-right 中浏览。

原文作者:彭泽文,阿里巴巴UC事业部高级开发工程师,有改动。

X-protocol 的定位是云原生、高性能、低侵入性的通用 Service Mesh 落地方案,依托 Kubernetes 基座,利用其原生的服务注册和服务发现机制,支持各种私有 RPC 协议低成本、易扩展的接入,快速享受 Service Mesh 所带来的红利。

本文将以 Dubboarrow-up-right 为例,演示 Dubbo on x-protocol 场景下 Service Mesh 路由功能,涵盖 Version route 、Weighted route 功能。

关于 x-protocol 的介绍请参考 蚂蚁金服开源的 SOFAMesh 的通用协议扩展解析arrow-up-right

前期准备

  1. 安装 VM Driver,推荐安装 Virtual Box、Mac 用户也可以选择 hyperkit

  2. 了解 Istio Traffic Management 相关概念

部署

先看部署效果图:

Mosn x-protocol部署图

本示例中dubbo-consumer的部署方式采用直连模式,即不走注册中心,完全依托kubernetes平台提供的服务注册及服务发现能力。

1. 安装 Kubernetes

安装 kubectl 命令行工具 推荐使用 Kubernetes 1.10 版本,并使用合适的 VM Driver,推荐使用默认的 VirtualBox。

Mac OSX 用户使用的 hyperkit 需要特别指定:

等待 Kubernetes 启动完毕,通过 kubectl 命令检查

2. 部署 SOFAMesh

本示例演示从源代码的 master 分支直接安装最新的 SOFAMesh,安装过程使用 Helm 完成。

从 GitHub 拉取最新代码:

创建 SOFAMesh 需要的 CRD:

使用 Helm 安装 SOFAMesh:

安装 istioctl 命令行工具:

3. 创建示例的命名空间

以下示例都将运行在 e2e-dubbo 命名空间下,如无 e2e-dubbo 命名空间,需先创建该命名空间:

4. 注入 MOSN

部署 dubbo-consumer 和 dubbo-provider,部署前需要先使用 istioctl 进行 sidecar 注入,以下示例采用手动注入方式,也可以通过 istio namespace inject 功能来自动注入。

5. 部署示例应用

部署 dubbo consumer service 及 dubbo provider service。

检查部署状态:

e2e-dubbo-consumer 是一个 Dubbo 客户端应用,它暴露了一个 8080 端口的 HTTP 服务,方便我们进行验证,e2e-dubbo-provider 是一个 Dubbo 应用。 当 e2e-dubbo-consumer 通过 12345 端口调用 e2e-dubbo-provider 时,流量会被 IPtable 规则拦截,导流给 MOSN。

验证路由能力

本示例将验证 Version route 和 Weighted route 能力。

1. 验证 Version Route 能力

本例将演示控制 dubbo-consumer的所有请求指向 dubo-provider-v1 配置DestinationRule:

dubbo-consumer.destinationrule.yaml 内容如下:

配置VirtualService:

dubbo-consumer.version.vs.yaml 内容如下:

路由策略已经生效,可以 http 请求 dubbo consumer 来触发 rpc 请求观察效果,由于使用 Minikube 的关系,需要启动一个 Pod 用来测试

清理路由策略:

退出 Minikube shell

2. 验证 Weight Route 能力

本例将演示控制 dubbo-consumer 的请求指向 dubo-provider-v1,dubo-provider-v2。并控制流量分配比例为 v1:20%,v2:80%。

配置DestinationRule:

dubbo-consumer.destinationrule.yaml 内容如下:

配置 VirtualService:

dubbo-consumer.weight.vs.yaml 内容如下:

路由策略已经生效,可以 http 请求 dubbo consumer 来触发 rpc 请求观察效果:

清理路由策略:

SOFAMesh Github 地址:https://github.com/sofastack/sofa-mesharrow-up-right

参考文档

Last updated

Was this helpful?