作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul

为什么要学习网关?

答:作为网站的唯一入口,控制权限,保证网站安全

功能:控制权限(鉴权)、分发请求(动态路由)

前言:来模拟一个需要用网关的场景

使用Spring Cloud实现微服务的架构基本成型,大致是这样的:
作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第1张图片
我们使用Spring Cloud Netflix中的Eureka实现了服务注册中心以及服务注册与发现;而服务间通过Ribbon或Feign实现服务的消费以及均衡负载;为了使得服务集群更为健壮,使用Hystrix的融断机制来避免在微服务架构中个别服务出现异常时引起的故障蔓延。

在该架构中,我们的服务集群包含:内部服务Service A和Service B,他们都会注册与订阅服务至Eureka Server,而Open Service是一个对外的服务,通过均衡负载公开至服务调用方。我们把焦点聚集在对外服务这块,直接暴露我们的服务地址,这样的实现是否合理,或者是否有更好的实现方式呢

先来说说这样架构需要做的一些事儿以及存在的不足

  • 首先,破坏了服务无状态特点。
    • 为了保证对外服务的安全性,我们需要实现对服务访问的权限控制,而开放服务的权限控制机制将会贯穿并污染整个开放服务的业务逻辑,这会带来的最直接问题是,破坏了服务集群中REST API无状态的特点。
    • 从具体开发和测试的角度来说,在工作中除了要考虑实际的业务逻辑之外,还需要额外考虑对接口访问的控制处理。
  • 其次,无法直接复用既有接口。
    • 当我们需要对一个即有的集群内访问接口,实现外部服务访问时,我们不得不通过在原有接口上增加校验逻辑,或增加一个代理调用来实现权限控制,无法直接复用原有的接口。

面对类似上面的问题,我们要如何解决呢?答案是:服务网关!

为了解决上面这些问题,我们需要将权限控制这样的东西从我们的服务单元中抽离出去,而最适合这些逻辑的地方就是处于对外访问最前端的地方,我们需要一个更强大一些的均衡负载器的 服务网关。

服务网关是微服务架构中一个不可或缺的部分。通过服务网关统一向外系统提供REST API的过程中,除了具备服务路由、均衡负载功能之外,它还具备了权限控制等功能。Spring Cloud Netflix中的Zuul就担任了这样的一个角色,为微服务架构提供了前门保护的作用,同时将权限控制这些较重的非业务逻辑内容迁移到服务路由层面,使得服务集群主体能够具备更高的可复用性和可测试性。

官网:https://github.com/Netflix/zuul
作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第2张图片
Zuul:维基百科:

电影《捉鬼敢死队》中的怪兽,Zuul,在纽约引发了巨大骚乱。

事实上,在微服务架构中,Zuul就是守门的大Boss!一夫当关,万夫莫开!
作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第3张图片

Zuul加入后的架构

作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第4张图片
不管是来自于客户端(PC或移动端)的请求,还是服务内部调用。一切对服务的请求都会经过Zuul这个网关,然后再由网关来实现 鉴权、动态路由等等操作。Zuul就是我们服务的统一入口。

作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第5张图片

创建网关的步骤:

1 创建项目

2 导入jar包:spring-cloud-starter-netflix-zuul

3 配置yml文件

4 开启网关服务

5 修改代码

网关功能:

  1. 动态路由(分发请求)
    • 只需要在yml中配置路由对应的路径,即可
  2. 负载均衡
  3. 权限控制

创建项目 用脚本

作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第6张图片
作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第7张图片

3.3.2.编写启动类

通过@EnableZuulProxy注解开启Zuul的功能:

@SpringBootApplication
@EnableZuulProxy // 开启Zuul的网关功能
public class ZuulDemoApplication {

	public static void main(String[] args) {
		SpringApplication.run(ZuulDemoApplication.class, args);
	}
}

3.3.3.编写配置

server:
  port: 10010 #服务端口
spring: 
  application:  
    name: api-gateway #指定服务名

3.3.4.编写路由规则

我们需要用Zuul来代理user-service服务,先看一下控制面板中的服务状态:

作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第8张图片

  • ip为:127.0.0.1
  • 端口为:8081

映射规则:

zuul:
  routes:
    user-service: # 这里是路由id,随意写
      path: /user-service/** # 这里是映射路径
      url: http://127.0.0.1:8081 # 映射路径对应的实际url地址

我们将符合path 规则的一切请求,都代理到 url参数指定的地址

本例中,我们将 /user-service/**开头的请求,代理到http://127.0.0.1:8081

动态路由,路径应该是动态的才对

3.4.1.添加Eureka客户端依赖:zuul整合eureka

<dependency>
    <groupId>org.springframework.cloudgroupId>
    <artifactId>spring-cloud-starter-netflix-eureka-clientartifactId>
dependency>

3.4.2.开启Eureka客户端发现功能

@SpringBootApplication
@EnableZuulProxy // 开启Zuul的网关功能
@EnableDiscoveryClient
public class ZuulDemoApplication {

	public static void main(String[] args) {
		SpringApplication.run(ZuulDemoApplication.class, args);
	}
}

3.4.3.添加Eureka配置,获取服务信息

eureka:
  client:
    registry-fetch-interval-seconds: 5 # 获取服务列表的周期:5s
    service-url:
      defaultZone: http://127.0.0.1:10086/eureka
  instance:
    prefer-ip-address: true
    ip-address: 127.0.0.1

3.4.4.修改映射配置,通过服务名称获取

因为已经有了Eureka客户端,我们可以从Eureka获取服务的地址信息,因此映射时无需指定IP地址,而是通过服务名称来访问,而且Zuul已经集成了Ribbon的负载均衡功能。

zuul:
  routes:
    user-service: # 这里是路由id,随意写
      path: /user-service/** # 这里是映射路径
      service-id: user-service # 指定服务名称

启动测试
再次启动,这次Zuul进行代理时,会利用Ribbon进行负载均衡访问:
作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第9张图片

Zuul把Eureka里面所有的IP都拉取了过来。无需配置,因为都是默认配置好的,虽然我们看不见,也无需配置ribbon,因为自身携带。

日志中可以看到使用了负载均衡器:
作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第10张图片

3.5.简化的路由配置

在刚才的配置中,我们的规则是这样的:

  • zuul.routes..path=/xxx/**: 来指定映射路径。是自定义的路由名
  • zuul.routes..serviceId=/user-service:来指定服务名。

而大多数情况下,我们的路由名称往往和 服务名会写成一样的。因此Zuul就提供了一种简化的配置语法:zuul.routes.=

比方说上面我们关于user-service的配置可以简化为一条:

zuul:
  routes:
    user-service: /user-service/** # 这里是映射路径

省去了对服务名称的配置。

3.6.默认的路由规则

在使用Zuul的过程中,上面讲述的规则已经大大的简化了配置项。但是当服务较多时,配置也是比较繁琐的。因此Zuul就指定了默认的路由规则:

  • 默认情况下,一切服务的映射路径就是服务名本身。
    • 例如服务名为:user-service,则默认的映射路径就是:/user-service/**

也就是说,刚才的映射规则我们完全不配置也是OK的,不信就试试看。

作为网站的唯一入口,控制权限,保证网站安全:SpringCloud_Zuul_第11张图片

你可能感兴趣的:(springCloud)