当前位置:   article > 正文

【云原生】Apisix接入Nacos、K8s服务注册中心自动获取服务_apisix nacos

apisix nacos

背景

我在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接口

  1. syntax = "proto3";
  2. package member;
  3. service HelloService {
  4. rpc SayHello (SayHelloRequest) returns (SayHelloResponse) {
  5. }
  6. }
  7. message SayHelloRequest {
  8. string name = 1;
  9. }
  10. message SayHelloResponse {
  11. int32 code = 1;
  12. string message = 2;
  13. bool success = 3;
  14. SayHelloData data = 4;
  15. }
  16. message SayHelloData {
  17. string name = 1;
  18. string content = 2;
  19. }

放进Apisix里一份

路由

一定要选择插件

  1. {
  2. "_meta": {
  3. "disable": false
  4. },
  5. "method": "SayHello",
  6. "proto_id": "1",
  7. "service": "member.HelloService"
  8. }

测试一下,还是先不经过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

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

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/羊村懒王/article/detail/214048
推荐阅读
相关标签
  

闽ICP备14008679号