SPRINGCLOUD五大组件及相关注解整理

四、Zuul-服务网关

a. 简介、功能

Zuul简介

Zuul相当于是第三方调用(app应用端和PC端)和服务提供方之间的防护门。作为前端服务(Edge Service也称边缘服务,前端服务的作用是对后端服务做必要的聚合和裁剪后暴露给外部不同的设备,如PC,Pad或者Phone),Zuul旨在实现动态路由,监控,弹性和安全性。它具备根据需求将请求路由到多个AWS自动弹性伸缩组的能力。

Zuul能做什么

Netflix API流量的量级和多样性随时可能导致生产环境故障而没有预警。因此需要一个系统能使我们迅速改变策略行为,以便应对各种情况。 Zuul使用一些不同类型的过滤器,使我们能够快速灵活地将功能应用于我们的前端服务。这些过滤器具有以下功能:

(1)- 权限控制和安全性–为每个请求提供身份认证,并拒绝不满足条件的请求。

(2)- 预警和监控–跟踪前端有意义的请求和统计数据,以便我们准确了解生产环境运行状况。

(3)- 动态路由–根据需求将请求动态地路由到不同的后端集群。

(4)- 压力测试–逐渐增大到集群的流量,以便进行性能评估。

(5)- 负载均衡–为每种类型的请求分配容量并丢弃超过限额的请求。

(6)- 静态资源处理–直接在Zuul处理静态资源并响应,而并非转发这些请求到内部集群中。

(7)- 多区域弹性–实现跨AWS区域请求路由,扩大了ELB的使用范围,并使前端服务更接近我们的成员

b. 项目使用

1)添加依赖:

<!--添加zuul路由网关 -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-zuul</artifactId>
        </dependency>

2)配置文件信息:

server:
  port: 9527


spring:
  application:
    name: microservicecloud-zuul-gateway


eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka,http://eureka7003.com:7003/eureka
  instance:
    instance-id: gateway-9527.com
    prefer-ip-address: true


info:
  app.name: taosun-microservicecloud
  company.name: www.taosun.com
  build.artifactId: ${project.artifactId}
  build.version: ${project.version}


zuul:
  prefix: /taosun #访问前缀
  ignored-services: "*" #不能使用微服务名访问,只能使用别名
  routes:
    microservicecloud-dept: /mydept/** #前面为注册的微服务名: 微服务别名,因此可以注册多个微服务名
    microservicecloud-feign: /myfeign/** #前面为注册的微服务名: 微服务别名,因此可以注册多个微服务名
   
    

3)配置类注解:
在这里插入图片描述

4)添加网关过滤器,实现过滤拦截:

在这里插入图片描述
currentContext.setSendZuulResponse(false);设置为false时,请求将不会往下进行!

5)启动服务测试:

在这里插入图片描述

未设置token信息请求被拦截!
在这里插入图片描述

注意!
ignored-services: “*” #不能使用微服务名访问,只能使用别名

此属性表示无法通过服务注册名进行访问!

在这里插入图片描述

添加token信息后服务正常返回:
在这里插入图片描述

Spring Cloud是一个开源的微服务框架,提供了一系列的组件来简化微服务的开发和管理。其中包括了五大组件,分别为:服务注册与发现组件Eureka、分布式配置中心Config、服务消费者组件Feign、断路器组件Hystrix、网关组件Zuul。下面是这五大组件相关配置详解。 1. 服务注册与发现组件Eureka Eureka是一个基于REST的服务注册与发现组件,用于管理服务的注册和发现。Eureka提供了高可用性、动态扩展、故障转移等特性。在Spring Cloud中,Eureka作为服务注册中心,可以让微服务之间互相发现和调用。 Eureka的相关配置如下: ```yaml eureka: client: service-url: defaultZone: http://localhost:8761/eureka/ instance: prefer-ip-address: true # 是否使用IP注册到Eureka,默认为false instance-id: ${spring.cloud.client.hostname}:${server.port} # 设置服务实例ID,默认为主机名:端口 ``` 2. 分布式配置中心Config Config是一个分布式配置中心,用于管理应用程序的配置。Config提供了集中式管理配置的功能,可以让应用程序动态地获取配置信息。在Spring Cloud中,Config可以作为配置中心,让微服务获取配置信息。 Config的相关配置如下: ```yaml spring: cloud: config: uri: http://localhost:8888 profile: dev # 配置文件的环境标识,如dev、prod等 label: master # Git仓库的分支名或标签名,用于多人协作 ``` 3. 服务消费者组件Feign Feign是一个基于HTTP的RESTful服务客户端,用于调用服务。Feign可以让开发人员更方便地调用其他微服务,它将服务接口定义为Java接口,并使用注解进行配置。在Spring Cloud中,Feign可以作为服务消费者组件,让微服务之间进行调用。 Feign的相关配置如下: ```yaml feign: hystrix: enabled: true # 是否启用Hystrix断路器,默认为true ``` 4. 断路器组件Hystrix Hystrix是一个断路器组件,用于处理分布式系统中的延迟和故障。Hystrix可以让服务之间更加健壮,它通过监控服务调用的状态,自动地打开或关闭断路器,从而防止故障在整个系统中扩散。在Spring Cloud中,Hystrix可以作为断路器组件,让微服务更加稳定。 Hystrix的相关配置如下: ```yaml hystrix: command: default: execution: isolation: strategy: SEMAPHORE # Hystrix隔离策略,默认为THREAD,可设置为SEMAPHORE circuitBreaker: enabled: true # 是否启用断路器,默认为true requestVolumeThreshold: 20 # 在时间窗口内的最小请求数,默认为20 errorThresholdPercentage: 50 # 错误百分比阈值,默认为50% sleepWindowInMilliseconds: 5000 # 断路器打开后的休眠时间,默认为5000ms ``` 5. 网关组件Zuul Zuul是一个网关组件,用于路由和过滤微服务请求。Zuul可以让微服务之间更加灵活,它可以对请求进行路由、过滤、转发、聚合等操作。在Spring Cloud中,Zuul可以作为网关组件,让微服务之间的请求更加安全、高效。 Zuul的相关配置如下: ```yaml zuul: routes: user-service: /user-service/** # 定义路由规则,将/user-service/**的请求转发到user-service服务 ignored-patterns: /**/hystrix.stream # 忽略/hystrix.stream请求,避免被Hystrix监控 host: connect-timeout-millis: 20000 # 连接超时时间,默认为20000ms socket-timeout-millis: 20000 # 套接字超时时间,默认为20000ms ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值