SpringCloud之Zuul路由网关

1. 什么是zuul?

Zull包含了对请求的路由(用来跳转的)和过滤两个最主要功能:

其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础,而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验,服务聚合等功能的基础。Zuul和Eureka进行整合,将Zul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。

在这里插入图片描述
注意:Zuul 服务最终还是会注册进 Eureka

提供:代理 + 路由 + 过滤 三大功能!

2. Zuul能干嘛?

  • 路由
  • 过滤
    官方文档:https://github.com/Netflix/zuul/

3. Zuul案例

3.1 创建子模块

创建Maven普通子模块并命名为springcloud-zuul-9527

3.2 导入依赖

<!--我们需要实体类,所以需要把api model引过来-->
<dependencies>
    <!--springboot启动器-->
    <dependency>
        <groupId>org.mybatis.spring.boot</groupId>
        <artifactId>mybatis-spring-boot-starter</artifactId>
    </dependency>
    <!--junit-->
    <dependency>
        <groupId>junit</groupId>
        <artifactId>junit</artifactId>
    </dependency>
    <!--日志测试-->
    <dependency>
        <groupId>ch.qos.logback</groupId>
        <artifactId>logback-core</artifactId>
    </dependency>
    <!--test-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-test</artifactId>
    </dependency>
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-web</artifactId>
    </dependency>
    <!--jetty web服务器-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-starter-jetty</artifactId>
        <version>2.3.3.RELEASE</version>
    </dependency>
    <!--热部署工具-->
    <dependency>
        <groupId>org.springframework.boot</groupId>
        <artifactId>spring-boot-devtools</artifactId>
    </dependency>
    <!--eureka-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
        <version>2.2.5.RELEASE</version>
    </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-netflix-hystrix</artifactId>
        <version>2.2.5.RELEASE</version>
    </dependency>
    <!--zuul-->
    <dependency>
        <groupId>org.springframework.cloud</groupId>
        <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
        <version>2.2.5.RELEASE</version>
    </dependency>
</dependencies>

3.3 编写配置

application.yml

server:
  port: 9527

# spring配置
spring:
  application:
    name: springcloud-zuul

# 配置eureka
eureka:
  client:
    service-url:
      defaultZone: http://eureka7001.com:7001/eureka/,http://eureka7002.com:7002/eureka/,http://eureka7003.com:7003/eureka/
  instance:
    instance-id: www.javazqz.com
    prefer-ip-address: true

# 配置infonfo
info:
  app.name: springcloud-zuul-9527
  company.name: www.javazqz.com

3.4 开启注解支持

ZuulApplication_9527.java

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

3.5 启动测试

先启动:springcloud-eureka-7001,springcloud-eureka-7002,springcloud-eureka-7003
再启动:springcloud-provider-dept-hystrix-8001
最后启动:springcloud-zuul-9527
启动zuul服务的时候发现错误:
在这里插入图片描述
解决错误:
在启动类添加注解属性

@SpringBootApplication(exclude = DataSourceAutoConfiguration.class)

重新启动
在浏览器输入:http://eureka7003.com:7003/
在这里插入图片描述
http://www.javazqz.com:9527/springcloud-provider-dept/dept/get/6
发现通过这种方式也能访问,但是我们不能把服务给暴露出去,所以我们得隐藏或者弄个名称来替代。
在这里插入图片描述

3.6 更改服务名

application.yml
# 配置zuul
zuul:
  routes:
    mydept.serviceId: springcloud-provider-dept
    mydept.path: /mydept/**

在这里插入图片描述
发现原先的访问还是能访问,接下来我们来处理怎么把原先的给禁用掉。
在这里插入图片描述

3.7 禁用原先服务名访问

# 配置zuul
zuul:
  routes:
    mydept.serviceId: springcloud-provider-dept
    mydept.path: /mydept/**
  ignored-services: * #不能再使用这个路径访问了, ignored :忽略,隐藏全部的~
  prefix: java #设置公共的前缀

在这里插入图片描述
http://www.javazqz.com:9527/java/mydept/dept/get/7
在这里插入图片描述

内容参考:https://www.bilibili.com/video/BV1jJ411S7xr
仅用于学习!

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值