idea创建zuul网关实现路由功能入门实例

zuul这个框架现在以及停止更新了,但是我感觉学习框架需要了解其实现原理,知道是解决了哪些问题,面试问到的时候最起码知道这是干啥的,其余的都是扯淡。。。

spring cloud zuul 是作为微服务的网关出现的,微服务网关的作用就是解决客户端调用不同的微服务时,不能单独直连各个微服务假如直连的话,就会面临每个接收的微服务都需要自己的一套会话保持处理,过滤器拦截处理,签名校验等等问题,代码的冗余度会很高。打个比方微服务就好比医院提供负责体检的各个门诊,那网关就类似于去挂号。只有先经过挂号拿到挂号单,就可以直接去各个科室体检,各个科室类似于各个微服务。

sping cloud zuul提供了路由转发和过滤器两个功能,这篇随笔只介绍路由转发

路由转发就是加入服务配置了由A映射到B,那么当客户端访问A时,经过路由转发就相当于访问了B

创建一个SpringBoot项目,引入zuul的项目依赖,需要注意对应的版本

<dependency>
  <groupId>org.springframework.cloud</groupId>
  <artifactId>spring-cloud-starter-zuul</artifactId>
  <version>1.4.7.RELEASE</version>
</dependency>

在应用的启动类中需要加入@EnableZuulProxy注解 

@EnableZuulProxy
@SpringBootApplication
public class ZuulDemoApplication {

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

}

在配置文件中添加

spring.application.name=api-zuul
server.port=8554
zuul.routes.api-a.path=/api-a/**
zuul.routes.api-a.url=http://localhost:8056/

启动服务

访问http://localhost:8554/api-a/consumer/calldemo4就相当于访问了http://localhost:8056/consumer/calldemo4,注意不要加上应用名。

以上都是传统的路由转发,在微服务中引用了注册中心的话,利用eureka的实例,进行路由转发的实现将更加灵活。

先引入maven坐标

 <dependency>
   <groupId>org.springframework.cloud</groupId>
   <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
   <version>1.4.2.RELEASE</version>
 </dependency>

在应用主类上添加@EnableZuulProxy注解

@EnableZuulProxy
@SpringBootApplication
@EnableEurekaClient
public class ZuulDemoApplication {

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

}

配置文件:

spring.application.name=api-zuul
server.port=8554
eureka.client.service-url.defaultZone=http://localhost:8761/eureka
zuul.routes.api-a.path=/api-a/**
zuul.routes.api-a.url=http://localhost:8056/
zuul.routes.api-b.path=/api-b/**
zuul.routes.api-b.url=eureka-demo-consumer

查看eureka注册中心,发现服务已经注册上了

访问http://localhost:8554/api-b/consumer/calldemo4 

将代码传到gitee:cloud_demo: springcloud样例 (gitee.com)

posted on 2022-01-05 22:52  山水爱恋  阅读(338)  评论(0编辑  收藏  举报