学习nacos时按教程走发现nacos发现不了服务
先查网上的资料发现基本都是说缺少依赖的
需要3个依赖
org.springframework.cloud
spring-cloud-dependencies
${spring-cloud.version}
pom
import
com.alibaba.cloud
spring-cloud-alibaba-dependencies
${spring-cloud-alibaba.version}
pom
import
com.alibaba.cloud
spring-cloud-starter-alibaba-nacos-discovery
检查发现没有缺少依赖
后面查找发现是依赖版本不对,spring-cloud-alibaba-dependencies在spring cloud官网上的最新版本不匹配spring boot 和 spring cloud的最新版本,解决方案俩种
1:spring boot 和 spring cloud换成低版本,附可用版本一份
4.0.0
pom
org.springframework.boot
spring-boot-starter-parent
2.5.6
net.biancheng.c
spring-cloud-alibaba-demo
1.0-SNAPSHOT
8
8
UTF-8
1.8
1.8
4.12
1.2.17
1.16.18
2020.0.4
com.alibaba.cloud
spring-cloud-alibaba-dependencies
2021.1
pom
import
org.springframework.cloud
spring-cloud-dependencies
${spring-cloud.version}
pom
import
2:找了下spring-cloud-alibaba-dependencies的版本,找到有个2022.0.0.0-RC1的版本,试了下可行,同样附可用版本
4.0.0
org.springframework.boot
spring-boot-starter-parent
3.0.2
0.0.1-SNAPSHOT
pom
huangMeng_springCload
17
2022.0.1
2022.0.0.0-RC1
org.springframework.cloud
spring-cloud-dependencies
${spring-cloud.version}
pom
import
com.alibaba.cloud
spring-cloud-alibaba-dependencies
${spring-cloud-alibaba.version}
pom
import
org.springframework.cloud
spring-cloud-starter
org.springframework.boot
spring-boot-maven-plugin
因为是学习我使用的是第二种方法。
修改后发送请求时发现@LoadBalanced注解拦截失效了,查找了其他文章发现
由于 Ribbon 已经停更,2020Spring Cloud 在 Hoxton.M2 Released 版本将 Ribbon 剔除,并使用 Spring Cloud Loadbalancer 作为其替代品;
解决方法另外导入LoadBalanced的依赖
org.springframework.cloud
spring-cloud-loadbalancer
4.0.1
既然没有使用ribbon,负载均衡策略的配置也不太一样了,不能直接在yml配置文件配置了,已配置nacos的负载均衡策略为例,添加注解在RestConfig上指定对应配置就行,@LoadBalanced还是需要不要去掉
@LoadBalancerClient(value = "huangmeng-user", configuration = NacosLoadBalancerClientConfiguration.class)
NacosLoadBalancerClientConfiguration是nacos库里面写好了的配置,配置其他策略就自己写配置文件就好了例如:
@Configuration
public class CustomLoadBalancerConfiguration {
// 参考 NacosLoadBalancerClientConfiguration
@Bean
public ReactorLoadBalancer roundRobinLoadBalancer(Environment environment, LoadBalancerClientFactory loadBalancerClientFactory) {
String name = environment.getProperty(LoadBalancerClientFactory.PROPERTY_NAME);
return new RoundRobinLoadBalancer(loadBalancerClientFactory.getLazyProvider(name, ServiceInstanceListSupplier.class), name);
}
}
@Configuration加了是全局配置,不加这是按LoadBalancerClient 或者LoadBalancerClients配置的来
之后整合gateway也出现问题访问不了,解决方法像之前一样导入loadbalance的依赖就好了
解决后至少暂时没问题了,只能我看的这个教程时效性有点差