在微服务中,如何使用feign在各个微服务中进行远程调用

在微服务中,如何使用feign在不同微服务中进行远程调用

在微服务中,如何使用feign在不同微服务中进行远程调用

步骤:

第一步:

引入feign依赖

xml 复制代码
        <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

这里没有指定版本号是因为...中的spring-cloud指定了版本号,如下

xml 复制代码
    <dependencyManagement>
        <dependencies>
            <dependency>
                <groupId>org.springframework.cloud</groupId>
                <artifactId>spring-cloud-dependencies</artifactId>
                <version>${spring-cloud.version}</version>
                <type>pom</type>
                <scope>import</scope>
            </dependency>
        </dependencies>
    </dependencyManagement>

第二步:在启动类中添加@EnableFeignClients注解

java 复制代码
@EnableFeignClients //开启远程调用
@SpringBootApplication
public class Application {

    public static void main(String[] args) {
        SpringApplication.run(Application.class, args);
    }

}

第三步:编写远程调用接口。现search服务需要调用product服务下/product/attr/info/{attrId}路径下的方法,该被调用的方法为:

java 复制代码
    @RequestMapping("/product/attr/info/{attrId}")
    public R info(@PathVariable("attrId") Long attrId){

        AttrRespVo respVo = attrService.getAttrInfo(attrId);

        return R.ok().put("attr", respVo);
    }

那么在search服务中编写的接口如下:我们需要保证接口中的方法与product中被调用的方法,方法名可以不同,但是他们的参数返回值类型请求路径要一致。接口方法发送get请求.

java 复制代码
@FeignClient(name = "product",url = "http://localhost:10000")
public interface ProductFeignService {
@GetMapping("/product/attr/info/{attrId}")
    public R attrInfo(@PathVariable("attrId") Long attrId);

}

第四步:在业务中远程调用,如下:

java 复制代码
@Autowired 
ProductFeignService productFeignService;

// 远程调用
Long attrId=1;
R r = productFeignService.attrInfo(attrId);
相关推荐
Gold Steps.13 分钟前
Zookeeper 集群部署与管理实践
linux·分布式·zookeeper·云原生
独立开阀者_FwtCoder21 分钟前
大模型私人定制:短短几行代码微调构建属于你的人工智能大模型(使用unsloth微调DeepSeek-r1大模型)
程序员·架构·代码规范
kong79069281 小时前
虚拟电商-延迟任务系统的微服务改造(二)
微服务·电商项目·延迟任务
NoneCoder1 小时前
Node.js系列(4)--微服务架构实践
微服务·架构·node.js
哈哈少儿8601 小时前
手把手教你搭建轻量级电商风控平台-业务篇
架构
每天三杯咖啡2 小时前
RAGFlow + LlamaIndex 本地知识库RAG增强架构与实现直播智能复盘
架构
Gold Steps.2 小时前
传统服务部署、虚拟化部署与云原生部署资源消耗对比与优化指南
linux·云原生
Wgllss4 小时前
Android之Apk全面瘦身,极致瘦身优化
android·性能优化·架构
程序猿阿伟4 小时前
《解锁元宇宙构建:AI与云原生区块链的协同奥秘》
人工智能·云原生·区块链
桂月二二4 小时前
云原生边缘计算:分布式智能的时代黎明
分布式·云原生·边缘计算