SpringCloud学习——Zuul路由网关

简介

zuul是SpringCloud全家桶中的一个组件,用来做网关。网关可以对请求进行过滤,对真实服务地址记性代理并且进行路由跳转等功能。

Zuul包含了对请求的路由和过滤两个最主要的功能:

  • 其中路由功能负责将外部请求转发到具体的微服务实例上,是实现外部访问统一入口的基础
  • 而过滤器功能则负责对请求的处理过程进行干预,是实现请求校验、服务聚合等功能的基础.

Zuul和Eureka进行整合,将Zuul自身注册为Eureka服务治理下的应用,同时从Eureka中获得其他微服务的消息,也即以后的访问微服务都是通过Zuul跳转后获得。

注意:Zuul服务最终还是会注册进Eureka

配置

搭建

新建一个模块,专门用来做网关。

pom.xml 如下:

<?xml version="1.0" encoding="UTF-8"?>
<project xmlns="http://maven.apache.org/POM/4.0.0"
         xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
         xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
    <parent>
        <artifactId>springcloudservice</artifactId>
        <groupId>org.example</groupId>
        <version>1.0-SNAPSHOT</version>
    </parent>
    <modelVersion>4.0.0</modelVersion>

    <artifactId>springcloudservice-zuul-9527</artifactId>
    <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>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-web</artifactId>
        </dependency>
        <dependency>
            <groupId>org.springframework.boot</groupId>
            <artifactId>spring-boot-starter-test</artifactId>
        </dependency>
    </dependencies>

</project>

application.properties 配置文件如下:

server.port=9527

spring.application.name=springcloudservice-zuul

eureka.client.service-url.defaultZone=http://eureka7001.com:7001/eureka,http://eureka7002.com:7002/eureka,http://eureka7003.com:7003/eureka
eureka.instance.instance-id=zuul-9527.com
eureka.instance.prefer-ip-address=true

info.app.name=zxb-springcloud
info.company.name=www.zxb.com
info.artifactId=${project.artifactId}
info.build.version=${project.version}

随后,修改主配置类

package com.zxb.springcloud;

import org.springframework.boot.SpringApplication;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.cloud.netflix.zuul.EnableZuulProxy;

@SpringBootApplication
@EnableZuulProxy // 开启 zuul 网关代理
public class Zuul9527_APP {
    public static void main(String[] args) {
        SpringApplication.run(Zuul9527_APP.class, args);
    }
}

最后进行测试: 启动eureka-server集群,启动一个提供者服务,启动zuul网关服务。

先不用网关进行测试: 访问 http://localhost:8001/user/get
SpringCloud学习——Zuul路由网关
数据出来了,没问题。

再启动路由网关进行测试: http://localhost:9527/springcloudservice-user/user/get。整和zuul以后,可以通过ip+网关端口+微服务名+接口路径进行访问。
SpringCloud学习——Zuul路由网关
我们并没有访问真实的服务地址localhost:8001,而是访问的zuul暴露出来的代理ip地址,一定程度上保护了服务器IP地址。

路由访问规则映射

现在我们的访问路径是这个: http://localhost:9527/springcloudservice-user/user/get。但是没人这么用,路径上还暴露了微服务地址。所以我们可以配置映射规则。

修改 application.properties 配置文件

zuul.routes.user.service-id=springcloudservice-user
zuul.routes.user.path=/myzuul/**

before(配置映射规则之前)
http://localhost:9527/springcloudservice-user/user/get

after(配置映射规则之后)
http://localhost:9527/myzuul/user/get

可以访问
SpringCloud学习——Zuul路由网关
看似没问题,但是我们访问原先的路径 http://localhost:9527/springcloudservice-user/user/get,发现也可以访问,这样显然不合理,所以在配置文件中加上如下配置即可:

# zuul.ignored-services=springcloudservice-user 忽略指定原先的路径
# 忽略所有的原先路径
zuul.ignored-services=*

SpringCloud学习——Zuul路由网关
此外,我们也可以给路径加上公共的访问前缀。比如我要加个 zj ,则可以在配置文件中这么写:

# / 不可省略
zuul.prefix=/zj

SpringCloud学习——Zuul路由网关

上一篇:微服务的网关


下一篇:微服务架构之「 API网关 」