zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter

测试中使用到的代码到在这里https://download.csdn.net/download/zhou920786312/10853300

 

Zuul:服务网关

 

  • 通过服务网关统一向外系统提供REST API的过程中,
  • 具备服务路由、均衡负载功能,权限控制等功能。 为微服务架构提供了前门保护的作用,同时将权限控制这些较重的非业务逻辑内容迁移到服务路由层面,使得服务集群主体能够具备更高的可复用性和可测试性。
  • 自身也是一个微服务,跟其它服务单元一样,都注册在eureka server上,可以相互发现。
  • zuul能感知到哪些服务在线,同时通过配置路由规则,可以将请求自动转发到指定的后端微服务上,对于一些公用的预处理(比如:权限认证,token合法性校验,灰度验证时部分流量引导之类),可以放在所谓的过滤器(ZuulFilter)里处理,这样后端服务以后新增了服务,zuul层几乎不用修改。

网关的应用场景

  1. 黑白名单:实现通过IP地址控制禁止访问网关功能,此功能是应用层面控制实现,再往前也可以通过网络传输方面进行控制访问。
  2. 日志:实现访问日志的记录,可用于分析访问、处理性能指标,同时将分析结果支持其他模块功能应用。
  3. 协议适配:实现通信协议校验、适配转换的功能。
  4.  身份认证:负责网关访问身份认证验证,此模块与“访问认证中心”通信,实际认证业务逻辑交移“访问认证中心”处理。
  5. 计流限流:实现微服务访问流量计算,基于流量计算分析进行限流,可以定义多种限流规则。
  6. 路由:路由是API网关很核心的模块功能,此模块实现根据请求,锁定目标微服务并将请求进行转发。此模块需要与“服务发布管理中心”通信。“服务发布管理中心”实现微服务发布注册管理功能,与其通信获得目标微服务信息。

 


zuul和feign的应用场景和区别

 

  • 1、zuul作为整个应用的流量入口,接收所有的请求,如app、网页等,并且将不同的请求转发至不同的处理微服务模块,其作用可视为nginx。
  • 2、feign则是将当前微服务的部分服务接口暴露出来,并且主要用于各个微服务之间的服务调用。
  • 3、两者的应用层次以及原理均不相同。
  • 3、zuul也含有hystrix和ribbon,基于http通讯的,可以直接代理服务就行。在它和服务间增加feign只会增加通讯消耗,没有特别的意义。feign在服务互相调用的时候用就行了,可以仿rpc通讯。
  • 4.Feign主要作客户端流控,Feign的负载均衡是基于Eureka实现的,
  • Zuul主要作服务端流控,并且Zuul的负载均衡结合Eureka实现易用性较好,并且Zuul我一般用在对第三方提供访问接口。
     

原理图

 zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter_第1张图片

 

Zuul的核心

Filter是Zuul的核心,用来实现对外服务的控制。Filter的生命周期有4个,分别是“PRE”、“ROUTING”、“POST”、“ERROR”,整个生命周期可以用下图来表示。

zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter_第2张图片

 

  • PRE: 这种过滤器在请求被路由之前调用。我们可利用这种过滤器实现身份验证、在集群中选择请求的微服务、记录调试信息等。
  • ROUTING:这种过滤器将请求路由到微服务。这种过滤器用于构建发送给微服务的请求,并使用Apache HttpClient或Netfilx Ribbon请求微服务。
  • POST:这种过滤器在路由到微服务以后执行。这种过滤器可用来为响应添加标准的HTTP Header、收集统计信息和指标、将响应从微服务发送给客户端等。
  • ERROR:在其他阶段发生错误时执行该过滤器。 除了默认的过滤器类型,Zuul还允许我们创建自定义的过滤器类型。例如,我们可以定制一种STATIC类型的过滤器,直接在Zuul中生成响应,而不将请求转发到后端的微服务。

Zuul中默认实现的Filter

类型 顺序 过滤器 功能
pre -3 ServletDetectionFilter 标记处理Servlet的类型
pre -2 Servlet30WrapperFilter 包装HttpServletRequest请求
pre -1 FormBodyWrapperFilter 包装请求体
route 1 DebugFilter 标记调试标志
route 5 PreDecorationFilter 处理请求上下文供后续使用
route 10 RibbonRoutingFilter serviceId请求转发
route 100 SimpleHostRoutingFilter url请求转发
route 500 SendForwardFilter forward请求转发
post 0 SendErrorFilter 处理有错误的请求响应
post 1000 SendResponseFilter 处理正常的请求响应

 

案例

zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter_第3张图片

 



	4.0.0

	
		com.atguigu.springcloud
		microservicecloud
		0.0.1-SNAPSHOT
	

	microservicecloud-zuul-gateway-9527

	
		
		
			org.springframework.cloud
			spring-cloud-starter-zuul
		
		
			org.springframework.cloud
			spring-cloud-starter-eureka
		
		
		
			org.springframework.boot
			spring-boot-starter-actuator
		
		
		
			org.springframework.cloud
			spring-cloud-starter-hystrix
		
		
			org.springframework.cloud
			spring-cloud-starter-config
		
		
		
			com.atguigu.springcloud
			microservicecloud-api
			${project.version}
		
		
			org.springframework.boot
			spring-boot-starter-jetty
		
		
			org.springframework.boot
			spring-boot-starter-web
		
		
			org.springframework.boot
			spring-boot-starter-test
		
		
		
			org.springframework
			springloaded
		
		
			org.springframework.boot
			spring-boot-devtools
		
	



zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter_第4张图片

@SpringBootApplication
//开启网关
@EnableZuulProxy
public class Zuul_9527_StartSpringCloudApp
{
    public static void main(String[] args)
    {
        SpringApplication.run(Zuul_9527_StartSpringCloudApp.class, args);
    }
}
 

 

zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter_第5张图片

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 
 
 
zuul: 
  #禁用这个微服务microservicecloud-dept
  #ignored-services: microservicecloud-dept
  #网关前缀
  prefix: /atguigu
  #禁用所有的微服务
  ignored-services: "*"
  routes: 
    #配置路由名称对应的微服务名称,也就是说,当访问/mydeptt/**就相当于文microservicecloud-dept/**
    mydept.serviceId: microservicecloud-dept
    mydept.path: /mydept/**
 
info:
  app.name: atguigu-microcloud
  company.name: www.atguigu.com
  build.artifactId: $project.artifactId$
  build.version: $project.version$

 

测试

启动3个eureka,一个microservicecloud-provider-dept-8001服务提供者,一个网关microservicecloud-zuul-gateway-9527

zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter_第6张图片

 

zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter_第7张图片

测试1

zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter_第8张图片

 

 

zuul 微服务网关+zuul和feign的应用场景和区别+原理图+Zuul的核心+Zuul中默认实现的Filter_第9张图片

 

 

 

 

 

 

 

你可能感兴趣的:(springcloud,web安全)