Spring Cloud Netflix 网关路由— Zuul 入门案例

通过前面的Eureka、Ribbon、Hystrix我们很容易构建一个简单的微服务架构,服务提供方将服务注册到服务注册与发现中心,服务调用这从服务发现与调用中心拉取服务列表,并且通过Ribbon提供的负载均衡器进行调用,在服务提供方出现故障的时候可以通过Hystrix进行断路而防止整个服务崩溃。但是这样还会存在一些问题,比如外部服务(web,app,第三方服务)访问这些服务需要经过不同的入口,又比如需要限流的时候需要每个服务提供者都有限流逻辑,造成臃肿,需要授权的时候也是一样需要每个服务去调用授权服务。调用关系如下图所示,调用关系显得杂乱无章。

为了解决上述问题,API网关的概念应运而生。其实Nginx可以当做网关,只是Nginx更多用于转发请求,对于统一认证等则无能为力。API网关是一个更为智能的应用服务器, 它的定义类似于面向对象设计模式中的门面模式, 它的存在就像是整个微服务架构系统的门面一样,所有的外部客户端访问都需要经过它来进行调度和过滤。它除了要实现请求路由、 负载均衡、 校验过滤等功能之外, 还需要更多能力,比如与服务治理框架的结合、 请求转发时的熔断机制、服务的聚合等一系列高级功能。如下为使用API网关之后的调用关系图:

在SpringCloud中了提供了基于Netflix Zuul实现的API网关组件Spring Cloud Zuul和自己的网关Spring Cloud Gateway,相对而言Spring Cloud Gateway的效率会更高,我们会在后面讲述,该部门主要讲述Spring Cloud Zuul的使用。Zuul将外部的请求过程划分为不同的阶段,每个阶段都提供了一系列过滤器,这些过滤器可以帮助我们实现以下功能。身份验证和安全性;观察和监控;动态路由;负载分配;静态晌应处理;路由的多样化等。

Zuul的引入

引入Zuul网关也非常简单,只需要引入名称为spring-cloud-starter-netflix-zuul的starter包即可。

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

引入Maven依赖之后,我们需要编写一个网关服务器,就像使用Eureka编写服务注册与发现中心一样,我们只需要一个简单的注解@EnableZuulProxy就可以开启Zuul网关服务。网关服务启动类如下:

@SpringBootApplication
@EnableZuulProxy
@EnableDiscoveryClient
public class ZuulGatewayApp {
    public static void main(String[] args) {
        SpringApplication.run(ZuulGatewayApp.class, args);
    }
}

上面我们写了一个最简单的Zuul网关,除了启动类之外,必不可少的当然还是配置文件。Zuul服务的配置分为两部分,一部分为Zuul服务的配置,比如实例名称,端口,注册中心地址等配置还有Zuul的个性化配置,另一部分则是网关路由的配置。这里我们不使用任何路由配置,就可以创建一个API网关。如下为没有路由配置的Zuul服务配置:

server:
  port: 9099 #API网关端口
eureka:
  instance:
    appname: zuul-gateway #实例名称
  client:
    fetch-registry: true   # 从Eureka获取实例
    register-with-eureka: true #注册到Eureka服务
    service-url:
      defaultZone: http://localhost:8671/eureka
spring:
  application:
    name: zuul-gateway #应用名称

然后,我们就做了一个最简单的API网关,这里我们的测试案例使用Hystrix中的代码,并且将hystrix-consume(代码参考Hystrix入门案例一篇)注册到Eureka注册中心,如果不使用API网关我们调用hystrix-consume直接在浏览器输入http://127.0.0.1:9091/hello/pharos,浏览器会返回hello,pharos的字符串。如果不配置任何路由Zuul会将实例名称作为路径转发,也就是说如果想要通过Zuul网关访问hystrix-consume服务,调用地址为http://127.0.0.1:9099/hystrix-consume/hello/pharos,也会返回hello,pharos的字符串。

本篇只是介绍Zuul网关的简单使用,不需要任何多余的配置,仅仅引入Zuul包并且从注册中心拉取服务,开始网关注解,即可以创建一个网关服务器,当然Zuul可以进行自定义配置使得网关路由更加多样化。Zuul的配置这篇不做任何说明,下一篇会重点介绍Zuul配置的用法。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值