springcloud微服务分布式云架构SpringCloudZuul

Spring Cloud大型企业分布式微服务云构建的B2B2C电子商务平台源码请加企鹅求求: 三五三六二四七二五九

创新互联是一家专业提供大同企业网站建设,专注与网站建设、成都做网站H5页面制作、小程序制作等业务。10年已为大同众多企业、政府机构等服务。创新互联专业网站建设公司优惠进行中。

POM依赖


        
            org.springframework.cloud
            spring-cloud-starter-netflix-eureka-client
        
        
            org.springframework.cloud
            spring-cloud-starter-netflix-zuul
        
    

启动类加上: @EnableZuulProxy 注解

配置:

spring:
  application:
    name: zuul-gateway
eureka:
  client:
    service-url:
      defaultZone: http://localhost:9001/eureka/
server:
  port: 9501
zuul:
  routes:
    #把order-server服务映射到路径/my-order/**
    order-test-route:
      serviceId: order-server
      path: /my-order/**
  #过滤指定的url,即不路由指定的url
  ignored-patterns:
    - /*/order/list 
# 当hystrix的值小的时候,hystrix生效,当ribbon.ReadTimeout小的时候,ribbon生效    
# 注意:只有zuul路由是url是才生效
# 如果使用的是serviceId 需要使用 ribbon.ReadTimeout 和 ribbon.SocketTimeout)
hystrix:
  command:
    default:
      execution:
        timeout:
          enabled: true
        isolation: #命令的执行超时时间  超时将执行回退
          thread:
            timeoutInMilliseconds: 8000
ribbon:
  ReadTimeout: 10000  #读取超时时间
  ConnectTimeout: 10000
ignored-patterns 为忽略指定的API
自定义过滤器需要实现ZuulFilter接口:
/**
 * 用户访问时触发
 *
 * @author 阮胜
 * @date 2018/7/19 21:48
 */
@Component
public class TokenFilter extends ZuulFilter {
    private static final String TOKEN = "token";
    /**
     * 过滤器类型
     *
     * @return
     */
    @Override
    public String filterType() {
        return FilterConstants.PRE_TYPE;
    }
    /**
     * 过滤器在过滤器链中的位置
     *
     * @return
     */
    @Override
    public int filterOrder() {
        return FilterConstants.PRE_DECORATION_FILTER_ORDER - 1;
    }
    /**
     * 返回值为true时执行过滤器,false则不执行当前过滤器
     *
     * @return
     */
    @Override
    public boolean shouldFilter() {
        return true;
    }
    /**
     * 用户访问时触发该过滤器
     *
     * @return
     * @throws ZuulException
     */
    @Override
    public Object run() throws ZuulException {
        RequestContext requestContext = RequestContext.getCurrentContext();
        HttpServletRequest request = requestContext.getRequest();
        String token = request.getParameter(TOKEN);
        if (StringUtils.isEmpty(token)) {
            requestContext.setSendZuulResponse(false);
            requestContext.setResponseStatusCode(HttpStatus.SC_UNAUTHORIZED);
        }
        return null;
    }
}
/**
 * 用户访问完要返回的时候触发
 * @author 阮胜
 * @date 2018/7/19 21:57
 */
@Component
public class PostFilter extends ZuulFilter {
    @Override
    public String filterType() {
        return FilterConstants.POST_TYPE;
    }
    @Override
    public int filterOrder() {
        return FilterConstants.SEND_RESPONSE_FILTER_ORDER - 1;
    }
    @Override
    public boolean shouldFilter() {
        return true;
    }
    @Override
    public Object run() throws ZuulException {
        RequestContext requestContext = RequestContext.getCurrentContext();
        HttpServletResponse resp = requestContext.getResponse();
        resp.setHeader("auth", "test auth");
        return null;
    }
}

分享标题:springcloud微服务分布式云架构SpringCloudZuul
网站链接:http://ybzwz.com/article/iggdoi.html