ribbon使用eureka的meta进行动态路由

使用eureka的元数据信息,再配上ribbon的路由功能,就可以在api-gateway实现很多功能,比如灰度测试、生产调试等等。下面介绍一下,怎么使用jmnarloch大神提供的ribbon-discovery-filter-spring-cloud-starter,利用简单的几行代码搞定这一切。

maven

        
            io.jmnarloch
            ribbon-discovery-filter-spring-cloud-starter
            2.1.0
        

eureka元数据配置

eureka:
  instance:
    metadataMap:
      tag: pre-prod

路由

@Component
public class DynamicRoutesFilter extends ZuulFilter {

    private static final Logger LOGGER = LoggerFactory.getLogger(DynamicRoutesFilter.class);

    @Override
    public String filterType() {
        return "pre";
    }

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

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

    @Override
    public Object run() {
        RequestContext requestContext = RequestContext.getCurrentContext();
        HttpServletRequest request = requestContext.getRequest();
        String tag = request.getHeader("tag");
        if(tag != null){
            RibbonFilterContextHolder.getCurrentContext().add("tag", tag);
        }

        return null;
    }
}

根据请求的tag,路由到标记有指定tag值的服务。注意,如果请求不指定tag,则代码需要判空一下,另外不指定tag的话,则默认所有同名的服务都会被路由到。

doc

  • Spring Cloud: Ribbon dynamic routing

想获取最新资讯,请关注微信公众号

ribbon使用eureka的meta进行动态路由_第1张图片
qrcode_for_gh_121b87c80448_258.jpg

你可能感兴趣的:(ribbon使用eureka的meta进行动态路由)