Spring Cloud Gateway源码解析-03-RouteDefinitionLocator、RouteLocator解析


系列文章

创作不易,如果对您有帮助,麻烦辛苦下小手点个关注,有任何问题都可以私信交流哈。
祝您虎年虎虎生威。


SCG初始化解析之Route、Predicate、Filter的构建原理中我们已经了解过RouteDefinitionLocator,**先来了解下这两个接口涉及的类关系。
在这里插入图片描述

RouteDefinitionLocator

RouteDefinitionLocator接口中只有一个方法就是#getRouteDefinitions,通过方法名称可以看出来,该方法是用来获取所有的RouteDefinition的,在第一节我们了解到,路由信息可以从配置文件中来,并且对应的实现类为PropertiesRouteDefinitionLocator,SCG其实还支持从其他源获取路由信息,比如配置中心,对应的类为DiscoveryClientRouteDefinitionLocator(后边的文章会进行详细讲解),从SCG的官方文档上还可以看到在未来的版本中将会基于数据库(如Redis、MongoDB和Cassandra)来获取路由,在2.2.6.RELEASE版本中,可以看到有一个接口RouteDefinitionRepository,但是只有一个实现类InMemoryRouteDefinitionRepository,估计未来版本会添加基于数据库的实现。

RouteDefinitionRepository

在这里插入图片描述

InMemoryRouteDefinitionRepository

InMemoryRouteDefinitionRepository实现了RouteDefinitionRepository接口,RouteDefinitionRepository继承了RouteDefinitionLocatorRouteDefinitionWriter,在RouteDefinitionWriter中定义了两个方法save和delete,用于添加和删除路由信息。

InMemoryRouteDefinitionRepository是基于内存的路由定义仓库,同时也是唯一提供的实现类。我们可以根据需要自定义扩展,存放到其它的存储介质中。

public interface RouteDefinitionWriter {

	Mono<Void> save(Mono<RouteDefinition> route);

	Mono<Void> delete(Mono<String> routeId);

}

CompositeRouteDefinitionLocator

此类主要是用于将我们不同来源的路由信息组合到一起供RouteDefinitionRouteLocator来使用。

CachingRouteDefinitionLocator

看名称是做缓存用的,但这个版本并没有使用。

RouteLocator

在这里插入图片描述

RouteLocator接口中只有一个方法getRoutes

public interface RouteLocator {

	Flux<Route> getRoutes();

}

通过方法名可以看出是用来获取所有的路由。

RouteDefinitionRouteLocator

RouteDefinitionRouteLocator是用来将RouteDefinitionLocatorGatewayFilterFactoryRoutePredicateFactory组装起来并生成Route,RouteDefinitionLocator就是CompositeRouteDefinitionLocator

自定义RouteLocator

通过RouteLocatorBuilder,也就是SCG的API驱动来自定义路由信息。

CompositeRouteLocator

用来将RouteDefinitionRouteLocator和自定义RouteLocator组合合并。

CachingRouteLocator

通过名称看是做缓存的,那是怎么做缓存的呢?在上边的CompositeRouteLocator中的getRoutes方法中,其实是调用RouteDefinitionRouteLocator或者自定义的RouteLocatorgetRoutes方法,但是RouteDefinitionRouteLocator并没有在初始化时将Route组装好,因此在CachingRouteLocator初始化时会调用每个RouteLocatorgetRoutes组装好所有的Route并缓存,供RoutePredicateHandlerMapping调用。

@Bean
@Primary
@ConditionalOnMissingBean(name = "cachedCompositeRouteLocator")
public RouteLocator cachedCompositeRouteLocator(List<RouteLocator> routeLocators) {
	return new CachingRouteLocator(
			new CompositeRouteLocator(Flux.fromIterable(routeLocators)));
}

总结

可以发现,RouteDefinitionLocator的作用是汇聚不同源的路由信息RouteDefinitionRouteLocator可以直接自定义路由,还可以通过RouteDefinitionLocator获取所有的配置的RouteDefinition,最终转换成Route供调用方RoutePredicateHandlerMapping获取。

### 解决方案 #### 查找缺失的库版本 当遇到`ImportError: /usr/lib/x86_64-linux-gnu/libstdc++.so.6: version &#39;GLIBCXX_3.4.21&#39; not found` 错误时,表明系统中的`libstdc++`库缺少所需的`GLIBCXX_3.4.21` 版本。可以通过命令来确认具体的缺失情况: ```bash strings /usr/lib/x86_64-linux-gnu/libstdc++.so.6 | grep GLIBCXX ``` 这会列出当前安装的所有可用的`GLIBCXX`版本[^1]。 #### 动态库版本与GCC版本对应关系 不同版本的 GCC 编译器提供不同的`GLIBCXX` 符号支持。通常来说,较新版本的 GCC 支持更多更新的符号定义。因此,解决问题的关键在于获取包含所需`GLIBCXX` 版本的新版`libstdc++` 文件[^2]。 #### 获取并替换 `libstdc++.so.6` ##### 如果本地已有合适版本的 `libstdc++.so.6.0.x` 库文件 可以尝试找到更高版本的`libstdc++.so.6.0.x` 并将其复制到适当位置或者创建软链接指向它: 1. **拷贝或建立软连接** - 将高版本的`libstdc++.so.6.0.x` 复制至 `/usr/local/lib/` 或其他路径。 ```bash cp path_to_higher_version_libstdc++.so.6.0.x /usr/local/lib/ ``` - 创建软链以便应用程序能够识别 ```bash ln -sf /usr/local/lib/libstdc++.so.6.0.x /usr/local/lib/libstdc++.so.6 ``` 2. **验证新的 `libstdc++.so.6.0.x` 是否生效** 使用如下命令测试是否成功加载了新版库: ```bash ldd --version strings /usr/local/lib/libstdc++.so.6 | grep GLIBCXX ``` ##### 若未找到合适的 `libstdc++.so.6.0.x` 库文件 则需下载相应版本的 GCC 安装包,并从中提取出所需要的共享对象文件(`*.so`)。 1. **下载 GCC 源码或二进制发布版** 访问官方站点或其他可信资源网站下载适合目标平台架构(如 x86_64)且带有最新标准 C++ 运行时环境的支持版本。 2. **解压后定位到 libstdc++so 文件夹下**, 执行以下操作 - 提取压缩包并将其中的`libstdc++.so.*` 移动到自定义目录, 如 `$HOME/gcc-lib`. ```bash tar xf gcc-version.tar.gz mv gcc-version/x86_64-pc-linux-gnu/libstdc++-v3/src/.libs/libstdc++.so* $HOME/gcc-lib/ ``` - 设置 LD_LIBRARY_PATH 环境变量使程序优先查找此路径下的动态链接库 ```bash export LD_LIBRARY_PATH=$HOME/gcc-lib:$LD_LIBRARY_PATH ``` 3. **再次验证** 通过上述方法处理之后应该能有效解决由于缺乏指定版本`GLIBCXX` 导致无法正常工作的状况[^3].
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

壹氿

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值