GuliMall学习记录-46
依赖循环
问题描述
视频中为了引入nacos的配置注册和发现,直接对common进行依赖,但是之前common中也添加了对renren-fast的依赖,所以会出现依赖循环的报错。
解决方法
导入如下依赖和依赖管理:
<!--配置发现-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<exclusions>
<!--//丢弃ribbon-->
<exclusion>
<groupId>com.netflix.ribbon</groupId>
<artifactId>ribbon</artifactId>
</exclusion>
</exclusions>
</dependency>
<!--配置管理-->
<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-config</artifactId>
</dependency>
意外情况
导入后会进行报错,显示Bean初始化失败,报错Caused by: java.lang.ClassNotFoundException: org.springframework.boot.context.properties.ConfigurationBeanFactoryMetadata
是因为springboot和springcloud的版本不一致,进行如下修改:
将parent中的springboot版本号改为2.7.3,在Properties中添加<spring-cloud.version>2021.0.4</spring-cloud.version>
在依赖管理中添加
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>${spring-cloud.version}</version>
<type>pom</type>
<scope>import</scope>
</dependency>
重新运行会提示endpoint blank,这是因为没有配置注册管理信息,不用管。
gulimall-gateway配置
问题描述
添加了新的路由,运行renren-fast-vue来向后端请求验证码时,收到503拒绝服务,观察后端的Console,显示是LoadBalancerCacheManager not available, returning delegate without caching.
原因是Spring Cloud 2020.0.0版本之前会自动引入Netflix Ribbon依赖,Netflix Ribbon功能跟loadbalancer一样,因Netflix公司停止维护Ribbon后, 在Spring Cloud 2020.0.0版本之后Spring使用loadbalancer替代了Ribbon, 但是loadbalancer依赖需要手动引入。
解决办法
在gateway的pom中引入如下依赖:
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-loadbalancer</artifactId>
</dependency>
<dependency>
<groupId>com.github.ben-manes.caffeine</groupId>
<artifactId>caffeine</artifactId>
<version>2.9.3</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-context-support</artifactId>
<version>5.2.21.RELEASE</version>
</dependency>
运行后没有loadblancer的报错,但是仍然显示503找不到服务,这里就是版本不对应的问题了。我此时的cloud版本是2021.1
,但是依赖的common中的cloud.alibaba的版本是2.0.1.RELEASE
,将版本换为2021.1
后重新运行,验证码成功显示。