SpringCloud框架初探(七) :Zuul API路由功能

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u013628152/article/details/82937663

源码地址:SpringCloud学习源码

API网关是一个更为智能的应用服务器,它的定义类似于面向对象设计模式中的Facade模式,它的存在就像是整个微服务架构系统的门面一样,所有的外部客户端访问都需要经过它来进行调度和过滤。它除了要实现请求路由、 负载均衡、 校验过滤等功能之外,还需要更多能力,比如与服务治理框架的结合、请求转发时的熔断机制、服务的聚合等一系列高级功能。在SpringCloud中了提供了基于NetflixZuul实现的API网关组件Spring Cloud Zuul。

简单来说,就是既具备路由转发功能,又具备过滤器功能,比如将/aaa/**路径请求转发到service-a服务上,将/bbb/***路径请求转发到service-b服务上,比如过滤,对请求参数的信息进行过滤,不符合的进行过滤拦截等。

搭建Zuul网关服务:

pom.xml中加入:

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

@EnableZuulProxy启用Zuul网关服务

@SpringBootApplication
@EnableEurekaClient
@EnableZuulProxy
public class SpringcloudzuulApplication {

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

yml配置文件:

server:
  port: 5580  #端口号
 
spring:
  application:
    name: service-zuul  #服务注册中心测试名
 
zuul:
  routes:
    api-a:
      path: /user/**
      serviceId: provider-user  #如果是/user/**路径下的请求,则跳转到provider-user
    api-b:
      path: /book/**
      serviceId: provider-book  #如果是/book/**路径下的请求,则跳转到provider-book
 
eureka:
  client:
    serviceUrl:
      defaultZone: http://user:password123@localhost:8761/eureka

启动Eureka注册中心服务器,启动Eureka服务提供者provider-user,启动Eureka服务提供者provider-book,启动spring-cloud-zuul网关服务。

访问网关服务:
http://localhost:5580/user/simple/1 可以查询用户信息

在这里插入图片描述

访问网关服务:
http://localhost:5580/book/simple/1 可以查询图书信息

在这里插入图片描述

说明Zuul路由功能起作用了。

猜你喜欢

转载自blog.csdn.net/u013628152/article/details/82937663