【SpringCloud Greenwich版本】第六章:智能路由(zuul)

一、SpringCloud版本

本文介绍的Springboot版本为2.1.1.RELEASE,SpringCloud版本为Greenwich.RC1,JDK版本为1.8,集成环境为IntelliJ IDEA

二、zuul介绍

路由在微服务体系结构的一个组成部分。例如,/可以映射到您的Web应用程序,/api/users映射到用户服务,并将/api/shop映射到商店服务。Zuul是Netflix的基于JVM的路由器和服务器端负载均衡器。

Netflix使用Zuul进行以下操作:

  • 认证
  • 洞察
  • 压力测试
  • 金丝雀测试
  • 动态路由
  • 服务迁移
  • 负载脱落
  • 安全
  • 静态响应处理
  • 主动/主动流量管理

Zuul的规则引擎允许基本上写任何JVM语言编写规则和过滤器,内置Java和Groovy。

要在您的项目中包含Zuul,请使用组org.springframework.cloud和spring-cloud-starter-netflix-zuul的启动器。

三、创建zuul服务

  • 3.1创建

创建一个module,取名为cloudzuul,选择Cloud Routing,再勾选上Zuul,完成
【SpringCloud Greenwich版本】第六章:智能路由(zuul)_第1张图片创建完成的pom文件,可以看到spring-cloud-starter-netflix-zuul依赖

<?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">
    <modelVersion>4.0.0</modelVersion>
    <groupId>com.jthao</groupId>
    <artifactId>cloudzuul</artifactId>
    <version>0.0.1-SNAPSHOT</version>
    <name>cloudzuul</name>
    <description>Demo project for Spring Boot</description>

    <parent>
        <groupId>com.jthao</groupId>
        <artifactId>cloudser</artifactId>
        <version>0.0.1-SNAPSHOT</version>
    </parent>

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

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-netflix-eureka-server</artifactId>
        </dependency>

    </dependencies>

</project>
  • 3.2启动

在启动类上增加@EnableZuulProxy,开启zuul代理功能

package com.jthao.cloudzuul;

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

@EnableZuulProxy
@EnableDiscoveryClient
@SpringBootApplication
public class CloudzuulApplication {

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

}

修改配置文件,设置端口8006,服务名cloudzuul,配置服务注册中心
其中zuul.routes.api-a.pathzuul.routes.api-a.service-id是将所有/api-a/请求都转发给cloudcustomer服务,同理在此处也可增加api-b.path和api-b.service-id来设置所有请求都转发给cloudribbon

server.port=8006
spring.application.name=cloudzuul
eureka.client.service-url.defaultZone: http://localhost:8001/eureka/

zuul.routes.api-a.service-id=cloudcustomer
zuul.routes.api-a.path=/api-a/**
  • 3.3访问

启动cloudser和两个cloudclient服务,cloudclient服务端口分别8002,8003
启动zuul服务
通过浏览器多次访问http://localhost:8006//api-a/test?name=zull
我们可以看到如下展示

zull===端口:8002被调用了===
zull===端口:8003被调用了===

四、更多文章阅读

【SpringCloud Greenwich版本】汇总
【JAVA设计模式】汇总

你可能感兴趣的:(SpringCloud)