SpringCloud(五):网关与路由——Zuul

是什么?

  • 负责将外部请求 转发 到具体的微服务,实现外部访问统一入口的基础
  • 过滤器功能 负责对请求的处理过程进行干预,是实现请求校验、服务聚合的基础
  • 将Zuul注册进Eureka中,同时从Eureka中获取其他微服务信息,即以后的微服务都是通过Zuul跳转
  • 三大功能: 代理+过滤+路由

路由项目的构建

POM.XML

<dependencies>
    <!-- zuul路由网关 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-zuul</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-eureka</artifactId>
    </dependency>
    <!-- actuator监控 -->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-actuator</artifactId>
    </dependency>
    <!-- hystrix容错 -->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-hystrix</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-config</artifactId>
    </dependency>
    <!-- API -->
    <dependency>
        <groupId>online.abor</groupId>
        <artifactId>springcloud-api</artifactId>
        <version>${project.version}</version>
    </dependency>
</dependencies>

application.yml

server:
  port: 9527
spring:
  application:
    name: springcloud-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: abor-springcloud-zuul-gateway
  company.name: www.abor.online
  #  build.artifactId: $project.artifactId$
  build.artifactId: ${project.artifactId}
  #  build.version: $project.version$
  build.version: ${project.version}

hosts修改

127.0.0.1	myzuul.com

主启动类

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

测试

  1. 启动eureka集群
  2. 启动8001 provider
  3. 启动路由
  • eureka集群成功启动,并且provider和zuul都成功注册进eureka
    在这里插入图片描述
  • 不用路由正常访问
    在这里插入图片描述
  • 使用路由也能正常访问(访问格式:域名:端口/服务名称/URL)
    在这里插入图片描述

路由访问映射规则

代理真实的服务名地址

为什么?

  • 为了不将真实的服务名暴露,用一个虚拟的来代理真实的服务名

yml配置

zuul:
  routes:
    mydept.serviceId: springcloud-dept
    mydept.path: /mydept/**
  • 将原来的springcloud-deptmydept代替

测试

  • 可以用mydept正常访问
    在这里插入图片描述

禁用原来的服务名

为什么?
  • 原来的服务名还可以正常访问,为了系统的安全,采用 单入口单出口的策略
yml修改
  • 添加 zuul.ignored-services属性
  • 如果要将所有微服务的名称都禁用,赋值为 "*"
zuul:
  ignored-services: springcloud-dept # 禁用全部原微服务名称
  routes:
    mydept.serviceId: springcloud-dept
    mydept.path: /mydept/**
测试
  • 使用mydept可以正常访问
    在这里插入图片描述
  • 使用原服务名报404
    在这里插入图片描述

为所有的url添加统一的前缀

yml修改

  • 添加 zuul.prefix属性
zuul:
  routes:
    mydept.serviceId: springcloud-dept
    mydept.path: /mydept/**
  ignored-services: "*" # 禁用全部原微服务名称
  prefix: /abor # 设置所有URL的前缀

测试

  • 原访问路径不可用了
    在这里插入图片描述
  • 添加指定的前缀之后可以正常访问
    在这里插入图片描述
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值