背景
我在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
 
    
   其他的路由配置都是一样的操作,就省略了。



















