• eureka迁移到nacos--双服务中心注册


    服务注册中心的迁移有多种方式,官网使用nacos sync,还有民间开发的双注册中心组件eureka-nacos-proxy,但是我用了不太顺利,所以用的是阿里巴巴的双注册中心组件edas-sc-migration-starter

    spring boot:2.5.3

    1. 引入依赖
    <dependency>
        <groupId>org.springframework.cloudgroupId>
        <artifactId>spring-cloud-starter-netflix-eureka-serverartifactId>
    dependency>
    <dependency>
        <groupId>org.springframework.bootgroupId>
        <artifactId>spring-boot-starter-actuatorartifactId>
    dependency>
    <dependency>
        <groupId>com.alibaba.cloudgroupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-discoveryartifactId>
        <version>2.0.4.RELEASEversion>
    dependency>

    <dependency>
        <groupId>com.alibaba.cloudgroupId>
        <artifactId>spring-cloud-starter-alibaba-nacos-configartifactId>
        <version>2.0.4.RELEASEversion>
    dependency>
    <dependency>
        <groupId>com.alibaba.edasgroupId>
        <artifactId>edas-sc-migration-starterartifactId>
        <version>1.0.2version>
    dependency>
    • 1
    1. 正常启动即可发现两边都已经注册

    2. 如果要用open feign,需要在启动类排除ribbon自动配置,否则服务间调用会报错

    alt
    2021-08-18 16:00:58.368 ERROR 351892 --- [nio-8081-exec-1] o.a.c.c.C.[.[.[/].[dispatcherServlet]    : Servlet.service() for servlet [dispatcherServlet] in context with path [] threw exception [Handler dispatch failed; nested exception is java.lang.AbstractMethodError: org.springframework.cloud.netflix.ribbon.RibbonLoadBalancerClient.choose(Ljava/lang/String;Lorg/springframework/cloud/client/loadbalancer/Request;)Lorg/springframework/cloud/client/ServiceInstance;] with root cause

    java.lang.AbstractMethodError: org.springframework.cloud.netflix.ribbon.RibbonLoadBalancerClient.choose(Ljava/lang/String;Lorg/springframework/cloud/client/loadbalancer/Request;)Lorg/springframework/cloud/client/ServiceInstance;
     at org.springframework.cloud.openfeign.loadbalancer.FeignBlockingLoadBalancerClient.execute(FeignBlockingLoadBalancerClient.java:88) ~[spring-cloud-openfeign-core-3.0.3.jar:3.0.3]
    • 1

    点进去可以看到 应该是负载均衡时选择服务出现错误

    alt

    解决方案1. 在启动类屏蔽ribbon自动配置类

    alt

    此时feign会默认调用nacos的服务

    alt

    方案2. 阿里云官网看的,但是我试了会报另一个错误,所以就采用方案1

    alt

    本文由 mdnice 多平台发布

  • 相关阅读:
    VTK ImageData 与ITK、SimpleITK
    AJAX-解决回调函数地狱问题
    Zookeeper常见命令
    AWS 中文入门开发教学 1- 课程介绍
    Vue--插槽slot
    React的useLayoutEffect和useEffect执行时机有什么不同
    如何拓展同城的客户群体?小魔推助力把握同城精准流量!
    消息队列——引入的问题:重复消费&顺序消费&分布式事务
    CRM 概念:了解Leads、Prospect、MQL 和 SQL 的概念
    PMP考试点01
  • 原文地址:https://blog.csdn.net/zongzhankui/article/details/132580682