`

Java 版SpringCloud分布式微服务b2b2c电子商务- Zuul基于Consul配置及详

 
阅读更多

一.构建工程

  1.引入依赖

 <!--SpringBoot2.0以上版本需引入该依赖-->
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-netflix-zuul</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-discovery</artifactId>
</dependency>

 2.创建主类

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

} 

 3.配置application.properties

zuul.routes.api-a.path=/api-a/**  
zuul.routes.api-a.service-id=api-a    
zuul.routes.api-b.path=/api-b/**  
zuul.routes.api-b.service-id=api-b  

 这里存在 api-a 和 api-b 两个微服务应用, 当请求http://localhost:port/api-a/helloWorld, 会被路由转发至 api-a 服务的 /helloWorld 接口, 当请求http://localhost:port/api-b/helloWorld, 会被路由转发至 api-b 服务的 /helloWorld 接口. 当请求 URL 符合配置规则时, 了解springcloud架构可以加求求:三五三六二四七二五九,就会被转发至 service-id 对应的微服务应用接口.

5.4.配置请求过滤

SpringCloud Zuul 还有另一个和核心功能: 请求过滤. Zuul 允许开发者在 API 网关上通过定义过滤器来实现对请求的拦截与过滤, 实现方法非常简单, 只需继承 ZuulFilter 抽象类并实现它定义的4个抽象函数就可以完成对请求的拦截和过滤.

public class MyGatewayFilter extends ZuulFilter {  

  /*4种过滤器类型,   
  pre:可以在请求被路由之前调用,   
  route:在路由请求时候被调用,   
  post:在route和error过滤器之后被调用,   
  error:处理请求时发生错误时被调用*/   
  @Override   
  public String filterType() {   
    return "pre";  
  }  
    @Override  
    public int filterOrder() {  
        return 0;  //优先级为0,数字越大,优先级越低  
    }  

    @Override  
    public boolean shouldFilter() {  
        return true;  // 是否执行该过滤器,此处为true,说明需要过滤  
    }  

    @Override  
    public Object run() {  
        RequestContext ctx = RequestContext.getCurrentContext();  
        HttpServletRequest request = ctx.getRequest();  

        log.info(String.format("%s request to %s", request.getMethod(), request.getRequestURL().toString()));  

        Object accessToken = request.getParameter("token");  //获取token参数  
        if (accessToken == null) {  
            log.warn("token is empty");  
            ctx.setSendZuulResponse(false);  //过滤该请求, 不对其进行路由  
            ctx.setResponseStatusCode(401);  //返回错误码  
            ctx.setResponseBody("token is null!");  //返回错误内容  
            return null;   //Zuul还未对返回数据做处理  
        }  
    return null;  
    }  

 创建过滤器后,它并不会直接生效, 我们还需为其创建具体的 Bean 才能启动该过滤器.

@SpringBootApplication  
@EnableDiscoveryClient  
@EnableZuulProxy  
@RestController  
public class LixjApplication {  

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

    @Bean  
    public MyGatewayFilter myGatewayFilter(){  
        return new MyGatewayFilter();  
    }  
}  

 二. 路由详解

  1.路径匹配规则
/api-a/?    可以匹配 /api-a/ 之后拼接一个任务字符的路径 , 比如 /api-a/a , /api-a/b , /api-a/c
/api-a/    可以匹配 /api-a/ 之后拼接任意字符的路径, 比如 /api-a/a, /api-a/aaa, /api-a/bbb . 但它无法匹配 /api-a/a/b 这种多级目录路径
/api-a/   可以匹配 /api-a/* 包含的内容之外, 还可以匹配形如 /api-a/a/b 的多级目录路径
**

  2.路由匹配顺序

    随着版本的迭代, 我们需要对一个服务做一些功能拆分, 将原属于 api-a 服务的某些功能拆分到另一个全新的服务 api-a-part 中, 而这些拆分的外部调用 URL 路径希望能够符合规则 /api-a/part/ .*

zuul.routes.api-a.path=/api-a/**
   zuul.routes.api-a.service-id=api-a

   zuul.routes.api-a-part.path=/api-a/part/**
   zuul.routes.api-a-part.service-id=api-a-part

 在源码中, 路由规则是通过 LinkedHashMap 保存的, 也就是说, 路由规则的保存时有序的, 而内容的加

载是通过遍历配置文件中路由规则依次加入的, 所以导致问题的根本原因是对配置文件中内容的读取, 但上

述properties配置无法保证路由规则加载顺序, 我们需要使用 YML 文件来配置, 以实现有序的路由规则.

 

  zuul:  
routes:
api-a-part:
path=/api-a/part/
service-id=api-a-part 
api-a:
path=/api-a/
service-id=api-a

 

分享到:
评论

相关推荐

    spring-cloud-starter-netflix-zuul-2.0.0.RELEASE

    可用的spring-cloud-starter-netflix-zuul-2.0.0.RELEASE包,maven上的spring-cloud-starter-netflix-zuul-2.0.0.RELEASE已经没了。

    spring-cloud-starter-netflix-zuul.zip已经闭源的jar包,pom

    Spring Cloud是Spring框架针对分布式系统解决方案的一系列集成工具集合,其中包括Eureka(服务发现)、Hystrix(断路器)、Zuul(API网关)等组件。Zuul的核心功能在于为微服务提供动态路由、过滤和安全控制,它允许...

    spring-cloud-netflix-zuul-websocket, Zuul反向代理网络套接字支持.zip

    spring-cloud-netflix-zuul-websocket, Zuul反向代理网络套接字支持 spring-cloud-netflix-zuul-websocketspring 应用程序中支持Zuul反向代理web套接字支持的简单库。用法spring-cloud-netflix-zuul-websocket可以从...

    Spring Cloud Zuul带注册中心Consul

    Spring Cloud Zuul是基于Spring Boot实现的微服务网关,它提供路由转发、过滤器等功能,使得客户端可以方便地访问到后端微服务。在这个示例中,Zuul与Consul结合,使得Zuul能够动态地发现注册在Consul中的服务,实现...

    springcloud-ribbon-feign-hystrix-zuul-config

    在Spring Cloud框架中,"springcloud-ribbon-feign-hystrix-zuul-config"这个标题涉及到四个关键组件:Ribbon、Feign、Hystrix和Zuul,以及配置管理Config。这些组件都是构建分布式系统时常用的服务发现、客户端负载...

    简易的SpringCloud分布式微服务项目

    本项目名为"简易的SpringCloud分布式微服务项目",它旨在提供一个简单易懂的入门示例,帮助开发者理解如何利用SpringCloud实现微服务的搭建和管理。 1. **微服务概念**:微服务是一种软件开发方法,它提倡将单一...

    基于SpringCloud分布式微服务+微信小程序实现短视频社交app设计源码.zip

    《基于SpringCloud分布式微服务+微信小程序实现短视频社交App设计源码详解》 在现代互联网技术的推动下,短视频社交应用已经成为人们日常生活中不可或缺的一部分。本文将深入探讨如何利用SpringCloud分布式微服务...

    SpringCloud微服务分布式架构开发实战-50000-05-作业及参考答案.rar.rar

    SpringCloud是Java领域中广泛使用的微服务开发工具集,它提供了众多服务发现、配置管理、负载均衡、熔断机制等组件,使得开发者能够轻松构建分布式系统。 首先,我们需要了解SpringCloud的核心组件。Eureka是服务...

    springcloud2-hystrix-feign-zuul.zip

    Spring Cloud 是一个用于构建分布式系统的服务发现、配置管理和微服务连接工具集,它基于Netflix OSS组件构建。下面我们将深入探讨这些关键组件。 1. **Hystrix**: Hystrix是Netflix开发的一个库,用于处理服务间...

    spring-cloud-zuul(包含注册中心、服务生产者、服务消费者、zuul网关路由).zip

    《Spring Cloud Zuul:构建微服务的路由网关》 Spring Cloud Zuul 是一个基于 Netflix Zuul 的微服务网关,它提供了动态路由、过滤器以及面向服务的路由功能,是构建分布式系统的重要组件。在Spring Cloud生态中,...

    springcloud 分布式框架搭建

    SpringCloud 是一个基于 Java 的微服务开发框架,用于简化分布式系统构建的一系列工具集合。它提供了包括服务发现、配置管理、断路器、智能路由、微代理、控制总线、一次性令牌、全局锁、领导选举、分布式会话、集群...

    springboot+springcloud-eureka+springcloud-zuul

    springboot框架+springcloud-Eureka搭建+springcloud0-zuul搭建代码,可以帮助新手搭建,才用的是为服务架构,但只是把架子打起来了,没有过多逻辑代码,参考学习下,希望对你们有帮助

    Ideal版SpringCloud框架参考---分布式微服务架构参考

    本文将深入探讨标题" Ideal版SpringCloud框架参考---分布式微服务架构参考"所涵盖的关键知识点,并结合描述中的组件进行详细解析。 首先,Eureka是Spring Cloud中的服务注册与发现组件。它允许微服务实例向中心...

    07_SpringCloud-zuul整合分布式中心动态修改路由规则.md

    结合前面我们把路由规则写在项目的配置文件中.现在把结合SpringCloud-config 分布式配置中心,让配置文件更加的灵活。使用actuator 手动刷新,后面在说springcloud 消息总线 实现动态刷新配置。

    SpringCloud zuul jar包

    SpringCloud Zuul是Spring Cloud生态系统中的一个边缘服务和API网关组件。它的主要功能是作为微服务架构中的统一入口,负责路由转发、过滤器处理、负载均衡以及安全控制等任务。Zuul允许开发者在微服务架构中实现...

    springcloud入门代码基于Spring Cloud实现的服务网关Zuul源代码

    springcloud入门代码基于Spring Cloud实现的服务网关Zuul源代码 安装教程 Zuul pom.xml &lt;groupId&gt;org.springframework.cloud &lt;artifactId&gt;spring-cloud-starter-netflix-zuul application.yml server:...

    spring-cloud使用的各种示例

    - [spring-cloud-consul](https://github.com/ityouknow/spring-cloud-examples/tree/master/spring-cloud-consul): Spring Cloud 使用 Consul 作为服务中心示例 - [spring-cloud-gateway]...

    spring-cloud-starter-netflix-zuul-2.1.0.RELEASE.jar

    spring-cloud-starter-netflix-zuul-2.1.0.RELEASE

    基于SpringCloud开发的在线教育系统

    在线教育平台服务端基于Spring Boot构建,采用Spring Cloud微服务框架。 持久层:MySQL、MongoDB、Redis、ElasticSearch 数据访问层:使用Spring Data JPA 、Mybatis、Spring Data Mongodb等 业务层:Spring IOC、...

Global site tag (gtag.js) - Google Analytics