SpringCloud feign以内部接口方式调用服务,api,像dubbo一样的调用方式

以前使用的是dubbo,后来换了springcloud 后,使用feign的方式调用服务,由于对feign了解不深刻,在使用过程中遇到了写问题,总结一下,希望对有相同困扰的同学有所帮助~

先导入相关依赖

 
        <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>2.1.0.RELEASE</version>
        </dependency>

        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
            <version>2.1.1.RELEASE</version>
            <exclusions>
                <exclusion>
                    <artifactId>archaius-core</artifactId>
                    <groupId>com.netflix.archaius</groupId>
                </exclusion>
            </exclusions>
        </dependency>

        
        <dependency>
            <groupId>com.netflix.archaius</groupId>
            <artifactId>archaius-core</artifactId>
            <version>0.7.6</version>
            <exclusions>
                <exclusion>
                    <groupId>com.google.guava</groupId>
                    <artifactId>guava</artifactId>
                </exclusion>
            </exclusions>
        </dependency>

1.首先我们先简单写个接口在服务端

 

2.在controller层写一个对外的http 接口,要和上面的接口地址,命名完全一样

 

3.将api 通过maven deploy 发到maven私服

 

 

4.复制maven私服的 pom地址,到消费端的 service层(我是service层调用的)

        

 

5.在springboot 项目启动类中扫描到你的服务端的api接口的报名

@EnableFeignClients(basePackages = {"com.Your interface})

 6.测试接口 成功

 

 

7.遇到的问题

java.lang.NoClassDefFoundError: Lcom/netflix/config/CachedDynamicIntProperty;

解决方式:这个问题困扰了好久,最后发现是因为jar包冲突

这个是因为spring-cloud-starter-alibaba-nacos-discovery或者 spring-cloud-starter-openfeign 这两个jar包中的com.netflix.archaius 版本不对,通过exclusions 排除后,单独引用匹配的版本就可以了
 <dependency>
            <groupId>com.alibaba.cloud</groupId>
            <artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
            <version>2.1.0.RELEASE</version>
            <exclusions>
                <exclusion>
                    <artifactId>archaius-core</artifactId>
                    <groupId>com.netflix.archaius</groupId>
                </exclusion>
            </exclusions>
        </dependency>
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
            <version>2.1.1.RELEASE</version>
            <exclusions>
                <exclusion>
                    <artifactId>archaius-core</artifactId>
                    <groupId>com.netflix.archaius</groupId>
                </exclusion>
            </exclusions>
        </dependency>

==========================================================================


 <dependency>
            <groupId>com.netflix.archaius</groupId>
            <artifactId>archaius-core</artifactId>
            <version>0.7.6</version>
            <exclusions>
                <exclusion>
                    <groupId>com.google.guava</groupId>
                    <artifactId>guava</artifactId>
                </exclusion>
            </exclusions>
        </dependency>
  
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Cloud是一组用于构建分布式系统的开源框架,它为我们提供了一种轻量级的微服务架构的解决方案。而Dubbo是阿里巴巴开源的高性能RPC框架,用于构建分布式服务框架。而Feign是Spring Cloud提供的一种声明式的Web服务客户端,它可以与Dubbo进行集成,提供更加便捷的服务调用方式。 在集成DubboFeign之前,我们需要先将Dubbo注册到Spring Cloud的注册中心,使得Dubbo服务可以被Spring Cloud所管理。这样,我们就可以使用Feign作为Spring Cloud中的服务消费者来调用Dubbo提供的服务。通过Feign,我们可以避免编写繁琐的服务调用代码,只需要简单的声明式接口,并使用注解来定义具体的服务调用方法,Feign会动态生成代理实现类,自动处理服务调用的细节。 在使用Feign集成Dubbo时,我们需要在Spring Boot配置文件中进行相应的配置,声明需要调用Dubbo服务接口。然后,通过在代码中定义Feign接口,使用注解来标识调用Dubbo服务地址、服务方法等。当我们调用接口时,Feign会自动发起对Dubbo服务的远程调用。 通过将FeignDubbo集成,我们可以通过Spring Cloud的整体架构来统一管理和调用Dubbo服务,简化了代码编写和服务调用的过程。同时,Feign还具有负载均衡、容错等一系列特性,可以进一步提高系统的稳定性和可靠性。 综上所述,通过集成DubboFeign,我们可以更加方便地在Spring Cloud中调用和管理Dubbo服务,提高系统的可维护性和可扩展性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值