Zull路由网关

文章目录

1. Zull

官方文档:https://github.com/Netflix/zuul/

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

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

2. 入门案例

创建springcloud-zuul模块,添加路由服务
添加依赖

    <dependencies>
        <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-netflix-zuul -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-zuul</artifactId>
            <version>2.2.9.RELEASE</version>
        </dependency>

        <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-netflix-hystrix-dashboard -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix-dashboard</artifactId>
            <version>2.2.9.RELEASE</version>
        </dependency>

        <!--导入Hystrix依赖-->
        <!-- https://mvnrepository.com/artifact/org.springframework.cloud/spring-cloud-starter-netflix-hystrix -->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-hystrix</artifactId>
            <version>2.2.9.RELEASE</version>
        </dependency>
        <!--Eureka: Ribbon需要从Eureka服务中心获取到服务提供方的地址-->
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-client</artifactId>
            <version>3.0.4</version>
        </dependency>

        <!--api-->
        <dependency>
            <groupId>com.yanyu</groupId>
            <artifactId>springcloud-api</artifactId>
            <version>1.0-SNAPSHOT</version>
        </dependency>
        <!--web-->
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-devtools</artifactId>
        </dependency>
        <dependency>
            <groupId>com.netflix.ribbon</groupId>
            <artifactId>ribbon-loadbalancer</artifactId>
            <version>2.7.18</version>
        </dependency>
    </dependencies>

配置文件
application.yml

server:
  port: 9527

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: #实例的id
    instance-id: zuul9527.com
    prefer-ip-address: true # 显示ip

info:
  app.name: yanyu-springcloud # 项目名称
  company.name: yanyu.com # 公司名称

添加主启动类,开启Zuul注解

@SpringBootApplication
@EnableZuulProxy // 开启Zuul
public class ZuulApplication_9527 {

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

开启路由后,就可以通过路由访问资源

  • http://www.yanyu.com:9527/springcloud-provider-dept/dept/get/1
    • www.yanyu.com 域名,这里为自添加的域名映射
    • springcloud-provider-dept 微服务名称
    • /dept/get/1 服务

设置配置文件,自定义路由名,隐藏微服务名称

# zull 路由网关配置
zuul:
  # 路由相关配置
  routes:
    mydept.serviceId: springcloud-provider-dept # eureka注册中心的服务提供方路由名称
    mydept.path: /mydept/** # 将eureka注册中心的服务提供方路由名称 改为自定义路由名称
  # 微服务路径不能再访问了,*: 忽略,隐藏全部的服务名称
  ignored-services: "*"
  # 设置公共的前缀
  prefix: /haust

设置完成后,微服务名称被隐藏,不能再通过微服务名称访问,通过设置的自定义访问

  • http://www.cspstudy.com:9527/haust/mydept/dept/get/1
    • haust 前缀
    • mydept 自定义名
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值