如何使用.NETCore+Cloud实现API网关

这篇文章给大家介绍如何使用.NET Core + Cloud实现API网关,内容非常详细,感兴趣的小伙伴们可以参考借鉴,希望对大家能有所帮助。

创新互联建站主营小店网站建设的网络公司,主营网站建设方案,重庆APP开发公司,小店h5微信平台小程序开发搭建,小店网站营销推广欢迎小店等地区企业咨询

API 网关是系统的唯一入口,调用任何服务的请求都需要经过网关层,最终才可能到达目标服务,既然是必经之路,那我们可以在网关层进行一些通用的操作,如:认证、鉴权、限流、智能路由、缓存、日志、监控、超时、熔断、重试等等,这样既使整个框架条理清晰,也让开发者更多注重功能的逻辑实现。

常见的 API 网关项目有:KongTykNetflix zuulOcelot 等。在 Spring Cloud 中,Zuul 是其核心组件,下面将介绍 .NET Core 中通过 Zuul 来进行统一 API 调用。

如何使用.NET Core + Cloud实现API网关  
 

搭建 Zuul Server

  1. 在 IntelliJ IDEA 中新建项目,选 Spring Initializr 完成项目创建

  2. 在 pom.xml 添加 zuul 和 eureka-client  的依赖,我们将会把 Zuul Server 注册到 Eureka Server

    <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
    </dependency>

    <dependency>
     <groupId>org.springframework.cloud</groupId>
     <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
    </dependency>
  3. 在启动类上添加 EnableZuulProxy 注解

    @EnableZuulProxy
    @SpringBootApplication
    public class EurekaServiceApplication {
     public static void main(String[] args) {
       SpringApplication.run(EurekaServiceApplication.class, args);
     }
    }
  4. 修改 application.yml 配置文件(集群模式通过一个类似 gateway.xxx.com 的域名指向多个 Zuul  Server 实例即可

    spring:
     application:
       name: zuul-service

    server:
     port: 5555

    eureka:
     instance:
       hostname: server1
       # 超过这个时间没收到心跳就剔除这个服务,这个配置一般为服务刷新时间配置的三倍,默认90s
       lease-expiration-duration-in-seconds: 15
       # 服务刷新时间,默认30s
       lease-renewal-interval-in-seconds: 5
     client:
       service-url:
         defaultZone: http://server1:8001/eureka/,http://server2:8002/eureka/,http://server3:8003/eureka/
  5. 启动服务,访问:http://server1:8001/(请确保 Eureka Server 已启动),可以发现 Zuul Server 已在 5555 端口启动

 

创建 .NET Core 服务

这里直接基于文章 .NET Core + Spring Cloud:服务注册与发现 中的测试项目,修改 .NET Core 客户端服务的配置文件 services:base-service:url

"services": {
 "base-service": {
   "url": "http://server1:5555/base-service/" // 原来 http://base-service/
 }
}
 

因为我们的 Zuul Server 是启动在 server1 的 5555 端口,通过 Zuul 网关调用服务的路由规则是 http://server1:5555/ + {Application 小写},而基础服务的 Application名称为 BASE-SERVICE,所以 url 设置为 http://server1:5555/base-service/

如何使用.NET Core + Cloud实现API网关  
 

测试

 
访问 base-service

通过网关的路由地址 http://server1:5555/base-service/ 访问 api/values 接口,多次请求可测试负载均衡效果

 
如何使用.NET Core + Cloud实现API网关  
 
访问 client-service

通过网关的路由地址 http://server1:5555/client-service/ 访问 api/values 接口,而配置文件中的 base-service 设置的也是网关地址,所以实际在调用 base-service 也是通过网关

 
如何使用.NET Core + Cloud实现API网关  

关于如何使用.NET Core + Cloud实现API网关就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。

文章题目:如何使用.NETCore+Cloud实现API网关
分享路径:https://www.cdcxhl.com/article30/isjdso.html

成都网站建设公司_创新互联,为您提供搜索引擎优化网站维护网站制作商城网站网站设计公司移动网站建设

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 创新互联

成都定制网站建设