在上一篇中我们介绍 spring cloud zuul 不能删除route
对于这个问题我们可以理解zuul 为了防止因为个别因素导致 zuul模块通过config-service 拉取配置时出现拉取配置失败从而导致所有route被删除导致的一系列事故而做的容错处理。但是这样做的问题就是,当我们某一次出现误操作而删除网关,因为这个容错处理导致我们并没有发现问题,后续我们再次重启或者重推网关服务的话,就会发现出现问题而长时间没有发现问题的根源,进而花费大量时间去定位问题,从而导致重大事故,当然还有就是每次下网关route都需要重启网关浪费人力物力资源。因此在我的理解这种问题应该快速发现而不是将他隐藏,当然我们也不能破坏他的这个容错处理。所以我们可以采取一次只能删除一定数量的route,这样防止因为网络问题等不确定因数导致删除了不该删的route而导致重大事故问题。
但是具体改怎么去删除这个网关呢?
源码:
在ZuulProperties中我们可以发现route是被保存在一个map里面的
/**
* Map of route names to properties.
*/
private Map<String, ZuulRoute> routes = new LinkedHashMap<>();
public Map<String, ZuulRoute> 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<String, Object> configRoutes = routeConfig.getRoutes();
Map<String, ZuulProperties.ZuulRoute> oldRoutes = zuulProperties.getRoutes();
Set<String> configRoutesTemp = new HashSet<>(configRoutes.keySet());
Set<String> 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;
}
网友评论