zuul网关不能删除bugfix

在上一篇中我们介绍 spring cloud zuul 不能删除route
对于这个问题我们可以理解zuul 为了防止因为个别因素导致 zuul模块通过config-service 拉取配置时出现拉取配置失败从而导致所有route被删除导致的一系列事故而做的容错处理。但是这样做的问题就是,当我们某一次出现误操作而删除网关,因为这个容错处理导致我们并没有发现问题,后续我们再次重启或者重推网关服务的话,就会发现出现问题而长时间没有发现问题的根源,进而花费大量时间去定位问题,从而导致重大事故,当然还有就是每次下网关route都需要重启网关浪费人力物力资源。因此在我的理解这种问题应该快速发现而不是将他隐藏,当然我们也不能破坏他的这个容错处理。所以我们可以采取一次只能删除一定数量的route,这样防止因为网络问题等不确定因数导致删除了不该删的route而导致重大事故问题。
但是具体改怎么去删除这个网关呢?
源码:
在ZuulProperties中我们可以发现route是被保存在一个map里面的

    /**
     * Map of route names to properties.
     */
    private Map routes = new LinkedHashMap<>();


    public Map getRoutes() {
        return routes;
    }

相信看到这里大家都知道改怎么样去删除这个网关了。
具体步骤就是:

  • 从config-service 去拉取route的配置routeConfig
  • 将这个routeConfig和zuul 的routes进行diff
  • 然后将routeConfig路面少的route配置进行删除
    核心代码
    @Autowired
    private ZuulProperties zuulProperties;

    @Autowired
    private RouteConfig routeConfig;

    public void remove() {
        Map configRoutes = routeConfig.getRoutes();
        Map oldRoutes = zuulProperties.getRoutes();
        Set configRoutesTemp = new HashSet<>(configRoutes.keySet());
        Set oldRoutesTemp = new HashSet<>(oldRoutes.keySet());
        oldRoutesTemp.removeAll(configRoutesTemp);
        for (String invalidKey:oldRoutesTemp) {
                oldRoutes.remove(invalidKey);
        }
        zuulProperties.setRoutes(oldRoutes);
    }

如果怕因为个别因数导致一次性删除大量route,可以执行对oldRoutesTemp的数量进来判断,或者其他个性化定制。
比如:

        if(oldRoutesTemp.size() > 2 ){
            logger.error("不能同时删除两个以上的route: {}",
                              JSON.toJSONString(oldRoutesTemp));
            return;
        }

你可能感兴趣的:(zuul网关不能删除bugfix)