背景

我在K8s中部署了两个使用SpringCLoudK8s框架的微服务,每个服务既暴露了HTTP接口方便测试,也暴露了gRpc接口更接近生产,他们的端口如下所示:

常规功能

上游

我们可以在这里配置我们的服务

HTTP

配置一个HTTP服务,输入地址和端口就完成了。

然后我们去配置一个路由

选择我们第一步配置的服务

这里可以选择很多插件,有限流、gRpc转换等插件,我这里选择一个限流插件使用,gRpc的后面再演示

60s只能访问2次

配置完路由之后,点击查看

最后我们就可以测试一下了

我先不经过Apisix网关,直接调接口

这次经过网关,要访问网关的地址和端口,网关会根据我们的配置进行路由,9080是网关默认的端口,因为我在配置路由时给了域名,所以这里需要加上;测试成功。

gRpc

接下来我们测试一下协议转换吧,我们用postman调用Apisix,Apisix直接gRpc调用我的微服务service-provider,这里是模拟生产中app的调用。

上游

Protocol Buffers

这里需要把我们定义的PB文件,也放进Apisix一份,这个是我service-provider暴露的gRpc接口

syntax = "proto3";

package member;

service HelloService {

rpc SayHello (SayHelloRequest) returns (SayHelloResponse) {

}

}

message SayHelloRequest {

string name = 1;

}

message SayHelloResponse {

int32 code = 1;

string message = 2;

bool success = 3;

SayHelloData data = 4;

}

message SayHelloData {

string name = 1;

string content = 2;

}

放进Apisix里一份

路由

一定要选择插件

{

"_meta": {

"disable": false

},

"method": "SayHello",

"proto_id": "1",

"service": "member.HelloService"

}

测试一下,还是先不经过Apisix调用一下

然后经过Apisix再调用一次,发现结果是一样的,测试成功。

接外部注册中心

我们看到,我们再调用网关之前,需要配置上游,填入上游的地址和端口,但是端口是变的,每次服务重启之后都是变化的,而且网关本身也是要知道我们微服务架构中共有哪些服务,因为服务经常会上下线,网关路由需要感知到。Apisix支持外接Eureka、Nacos、Consul、K8s等注册中心,这里我们以Nacos和K8s为例。

Nacos

首先需要部署Nacos

然后把Nacos的地址http://124.222.91.116:8848放进 apisix_conf/config.yaml 文件中

这样就配置完成了,然后在上游中配置服务

这里就不测试了,很简单。

K8s

配置

apisix_conf/config.yaml

查看service-provider服务暴露的接口

配置上游

这里主要关注 服务名称 serviceName: [namespace] / [name] : [portName] ,这里官网也没个示例,费了很大的劲才解决。

HTTP

gRpc

其他的路由配置都是一样的操作,就省略了。

精彩内容

评论可见,请评论后查看内容,谢谢!!!
 您阅读本篇文章共花了: