SpringCloud教程 | 第7篇:服务网关Zuul配置

一、Zuul简介

Zuul的主要功能是路由转发和过滤器。路由功能是微服务的一部分,比如/api/user转发到到user服务,/api/shop转发到到shop服务。zuul默认和Ribbon结合实现了负载均衡的功能。

zuul有以下功能:

  • Authentication
  • Insights
  • Stress Testing
  • Canary Testing
  • Dynamic Routing
  • Service Migration
  • Load Shedding
  • Security
  • Static Response handling
  • Active/Active traffic management

二、准备工作

继续使用上一节的工程。在原有的工程上,创建一个新的工程。

三、创建microservicecloud-zuul-gateway工程

        3.1 POM配置




    
        mall
        com.linjia
        1.0-SNAPSHOT
    
    4.0.0

    com.linjia
    microservicecloud-zuul-gateway
    1.0-SNAPSHOT

    microservicecloud-zuul-gateway
    
    http://www.example.com

    
        UTF-8
        1.7
        1.7
    

    
        
        
            org.springframework.cloud
            spring-cloud-starter-zuul
        
        
            org.springframework.cloud
            spring-cloud-starter-eureka
        
        
        
            org.springframework.boot
            spring-boot-starter-actuator
        
        
        
            org.springframework.cloud
            spring-cloud-starter-hystrix
        
        
            org.springframework.cloud
            spring-cloud-starter-config
        
        
        
            com.linjia
            microservicecloud-api
            ${project.version}
        
        
            org.springframework.boot
            spring-boot-starter-jetty
        
        
            org.springframework.boot
            spring-boot-starter-web
        
        
            org.springframework.boot
            spring-boot-starter-test
        
        
        
            org.springframework
            springloaded
        
        
            org.springframework.boot
            spring-boot-devtools
        
    

3.2  yml文件配置

server:
    port: 9527

spring:
  application:
     name: microservicecloud-zuul-gateway
eureka:
  client:
    service-url:
       # defaultZone: http://localhost:7001/eureka   #将客户端注册进eureka服务列表内
        defaultZone: http://localhost:7001/eureka,http://localhost:7002/eureka,http://localhost:7003/eureka
  instance:
    instance-id: ${spring.cloud.client.ipAddress}:${server.port}   #自定义服务名称信息  启动多个服务做集群需要设置为不同的ID值
    prefer-ip-address: true   #访问路径可以显示IP地址


info:
    app.name: baidu-microcloud
    company.name: www.baidu.com
    build.artifactId: $project.artifactId$
    build.version: $project.version$

#第一步:启动注册中心
#第二步:启动 microservicecloud-zuul-gateway
#第三步:启动 microservicecloud-provider-dept 服务提供者
#        访问:http://localhost:8001/dept/get/1
#        访问:http://localhost:9527/microservicecloud-dept/dept/get/1
#        两个结果显示同样信息
#
# 路由映射配置
zuul:
#    ignored-services: "*"   #忽略多个服务方式"*"代替
    ignored-services: microservicecloud-dept       # 设置单个服务名称后真实URL无法访问:http://localhost:9527/microservicecloud-dept/dept/get/1  只可以虚拟URL访问
    prefix: /willow     #设置统一前缀路径    设置后访问:http://localhost:9527/willow/mydept/dept/get/1
    routes:
      mydept.serviceId: microservicecloud-dept
      mydept.path: /mydept/**            # 访问虚拟URl方式:http://localhost:9527/mydept/dept/get/1

3.3 启动类创建

package com.linjia;

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

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

配置完成;完成下面访问Zuul起到路由作用,yml配置文件中的zuul配置可有可无

#第一步:启动注册中心
#第二步:启动 microservicecloud-zuul-gateway
#第三步:启动 microservicecloud-provider-dept 服务提供者
#        访问:http://localhost:8001/dept/get/1
#        访问:http://localhost:9527/microservicecloud-dept/dept/get/1
#        两个结果显示同样信息
#
# 路由映射配置
zuul:
#    ignored-services: "*"   #忽略多个服务方式"*"代替
    ignored-services: microservicecloud-dept       # 设置单个服务名称后真实URL无法访问:http://localhost:9527/microservicecloud-dept/dept/get/1  只可以虚拟URL访问
    prefix: /willow     #设置统一前缀路径    设置后访问:http://localhost:9527/willow/mydept/dept/get/1
    routes:
      mydept.serviceId: microservicecloud-dept
      mydept.path: /mydept/**            # 访问虚拟URl方式:http://localhost:9527/mydept/dept/get/1

启动后访问注册中心 :http://localhost:7001/ 查看zuul是否注册

SpringCloud教程 | 第7篇:服务网关Zuul配置_第1张图片

四、服务过滤

 zuul不仅只是路由,并且还能过滤,做一些安全验证。继续改造工程;

     4.1创建过滤器

package com.linjia.com.linjia.springcloud.filter;

import com.netflix.zuul.ZuulFilter;
import com.netflix.zuul.context.RequestContext;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;
import org.springframework.stereotype.Component;

import javax.servlet.http.HttpServletRequest;

@Component
public class MyFilter extends ZuulFilter {

    private static Logger log = LoggerFactory.getLogger(MyFilter.class);
    @Override
    public String filterType() {
        return "pre";
    }

    @Override
    public int filterOrder() {
        return 0;
    }

    @Override
    public boolean shouldFilter() {
        return true;
    }

    @Override
    public Object run() {
        RequestContext ctx = RequestContext.getCurrentContext();
        HttpServletRequest request = ctx.getRequest();
        log.info(String.format("%s >>> %s", request.getMethod(), request.getRequestURL().toString()));
        Object accessToken = request.getParameter("token");
        if(accessToken == null) {
            log.warn("token is empty");
            ctx.setSendZuulResponse(false);
            ctx.setResponseStatusCode(401);
            try {
                ctx.getResponse().getWriter().write("token is empty");
            }catch (Exception e){}

            return null;
        }
        log.info("ok");
        return null;
    }

 
}
      4.2过滤器方法说明
filterType:返回一个字符串代表过滤器的类型,在zuul中定义了四种不同生命周期的过滤器类型,具体如下: 
  • pre:路由之前
  • routing:路由之时
  • post: 路由之后
  • error:发送错误调用
  • filterOrder:过滤的顺序
  • shouldFilter:这里可以写逻辑判断,是否要过滤,本文true,永远过滤。
  • run:过滤器的具体逻辑。可用很复杂,包括查sql,nosql去判断该请求到底有没有权限访问。
过滤器配置完成 ,
 访问:http://localhost:9527/willow/mydept/dept/get/1  未通过,
 返回:token is empty
访问:http://localhost:9527/willow/mydept/dept/get/1?token=22  通过,
返回:{"deptno":1,"dname":"123","db_source":"123"}



你可能感兴趣的:(SpringCloud)