springboot整合springcloud之feign

服务调用之OpenFeign

一、项目操作

1.引入依赖

                <dependency>
            <groupId>org.springframework.cloud</groupId>
            <artifactId>spring-cloud-starter-openfeign</artifactId>
        </dependency>

2.明确分工

明确谁作为服务的消费者,谁作为服务的提供者,这里场景是用户和优惠券,用户作为优惠券的消费者,厂家作为优惠券的提供者。

3.提供者提供具体的服务方法

@RequestMapping("/member/list")
public R membercoupons(){
    CouponEntity couponEntity = new CouponEntity();
    couponEntity.setCouponName("满100减10");
    return R.ok().put("coupons",Arrays.asList(couponEntity));
}

4.消费者注册申请服务的接口

在这里插入图片描述1是配置文件里的application-name,也就是服务的名字。
2是刚才定义的服务者方法的前两行,直接复制过来。

5.消费者使用接口调用提供者的服务

@Autowired
CounponFeignService counponFeignService;
@RequestMapping("/coupons")
public R test(){
    MemberEntity memberEntity = new MemberEntity();
    memberEntity.setNickname("张三");
    R membercoupons = counponFeignService.membercoupons();
    return R.ok().put("member",memberEntity)
            .put("coupons",membercoupons.get("coupons"));
}

6.消费者添加注解

@EnableFeignClients(basePackages = "com.atguigu.gulimall.member.feign")

后面是接口类的包名全类名。注解大概不加也行,那就得加@service到接口上注入到IOC容器。

二、检验

在这里插入图片描述

三、对比dubbo

dubbo:接口是共有的,在项目公有子模块里。提供者继承接口,提供实现类。消费者直接注入接口,调用就可以了。提供者的配置文件里记录提供服务的接口,一个服务可以多个接口提供(负载均衡)。一个接口当然也可以有多个实现类,可以手工选择。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

CtrlZ1

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值