笔记

在微服务中,若想要使用远程调用,需要引入spring-cloud-starter-openfeign(在使用注册中心的环境下)

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

由于open-feign是声明式的远程调用,所以需要编写一个接口,并且告诉SpringCloud这个接口需要调用远程服务。这个接口我放在公共模块下的feign中。

package top.ctong.gulimall.common.feign;

import org.springframework.cloud.openfeign.FeignClient;
import org.springframework.web.bind.annotation.RequestMapping;
import org.springframework.web.bind.annotation.RequestParam;
import top.ctong.gulimall.common.utils.R; import java.util.Map;
@FeignClient("gulimall-coupon")
@RequestMapping("/coupon/coupon")
public interface CouponFeignService { /**
* 通过自定义参数查询列表
* @param params 自定义参数
* @return R
* @author Clover You
* @date 2021/11/17 09:11
*/
@RequestMapping("/list")
R list(@RequestParam Map<String, Object> params);
}
  • @FeignClient("xxx") 该注解用于告诉SpringCloud这是一个远程调用接口,其中的value是你在注册中心中注册的服务名。

接口方法签名需要与被调用的远程服务签名一致,例如上面哪个代码要调用的远程服务:

package top.ctong.gulimall.coupon.controller;

@RestController
@RequestMapping("coupon/coupon")
public class CouponController {
@Autowired
private CouponService couponService;
/**
* 列表
*/
@RequestMapping("/list")
//@RequiresPermissions("coupon:coupon:list")
public R list(@RequestParam Map<String, Object> params){
PageUtils page = couponService.queryPage(params);
return R.ok().put("page", page);
}
}

接着还要使用@EnableFeignClients开启当前需要使用远程调用的这个服务的远程调用,并且指定你的远程调用接口在哪个包下。

@EnableFeignClients(basePackages = "top.ctong.gulimall.common.feign")
@EnableDiscoveryClient
@MapperScan("top.ctong.gulimall.member.dao")
@SpringBootApplication
public class GulimallMemberApplication { public static void main(String[] args) {
SpringApplication.run(GulimallMemberApplication.class, args);
} }
  • @EnableFeignClients 该注解用于开启当前服务的远程调用功能

    • basePackages 用于指定远程调用接口所在的包,方便服务启动的时候可以快速扫描到。他可以接收多个包名,因为它是一个String[]

最后在需要远程调用时注入对应的远程调用接口就好

package top.ctong.gulimall.member.controller;

@RestController
@RequestMapping("member/member")
public class MemberController { private final CouponFeignService couponFeignService; @Autowired
public MemberController(CouponFeignService couponFeignService, MemberService memberService) {
this.couponFeignService = couponFeignService;
this.memberService = memberService;
} @RequestMapping("/testFeignInvoke")
public R testFeignInvoke() {
Map<String, Object> parem = new HashMap<>(10);
return couponFeignService.list(parem);
}
}

错误(nacos)

如果在启动时出现 No Feign Client for loadBalancing defined. Did you forget to include spring-cloud-starter-loadbalancer? 错误,那么就是你的SpringCloud版本比较高,在高版本的SpringCloud中已经不再使用 spring-cloud-starter-netflix-ribbon 了,而是使用 spring-cloud-starter-loadbalancer 。而nacos还是使用的 spring-cloud-starter-netflix-ribbon

pom.xml文件中引入 spring-cloud-starter-loadbalancer 再启动就没毛病了。

<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-loadbalancer</artifactId>
<version>3.0.4</version>
</dependency>

在测试远程调用中发生 AbstractMethodError 异常。需要在 pom.xml排除 nacos 中引入的 ribbon 。否则 spring-cloud-starter-loadbalancer 无法工作。

<dependency>
<groupId>com.alibaba.cloud</groupId>
<artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId>
<exclusions>
<exclusion>
<groupId>com.netflix.ribbon</groupId>
<artifactId>ribbon</artifactId>
</exclusion>
</exclusions>
</dependency>

个人博客

最新文章

  1. sql: 去除数据库表中tab、空格、回车符等特殊字符的解决方法
  2. SQL Server中使用正则表达式
  3. 两种常用的启动和关闭MySQL服务
  4. [C++程序设计]变量的存储类别
  5. 自己拼接json字符串,现在用Gson来实现
  6. imagebutton、imageview的属性
  7. Vmware 中安装 Ubuntu Server (或者ubuntu 以文本界面登陆时) 分辨率无法全屏问题
  8. Linux - 简明Shell编程07 - 数组(Array)
  9. iOS App上架流程(2016详细版)来源DeveloperLY
  10. 查看Linux的所有线程
  11. leetcode56
  12. express中app.get和app.use的解析
  13. Freemarker入门
  14. windows下,将MySQL做成服务/脚本启动
  15. C#.NET常见问题(FAQ)-如何改变字符串编码
  16. 【BZOJ】【1419】Red is good
  17. python 判断两个列表是否有公共元素
  18. iOS 可能用到的三方框架
  19. Ansible应用领域
  20. spring boot 整合kafka 报错 Exception thrown when sending a message with key=&#39;null&#39; and payload=JSON to topic proccess_trading_end: TimeoutException: Failed to update metadata after 60000 ms.

热门文章

  1. 解决报错:Unable to process Jar entry [org/springframework/jmx/export/annotation/*****]
  2. 踩坑系列《三》 java -version 报错出现Error occurred during initialization of VM java/lang/NoClassDefFoundError:
  3. dg create datafile auto failed 排除处理
  4. Xcode相关
  5. Java(29)集合四Collections
  6. LDAP-初见
  7. DOS命令和快捷键
  8. ORB_SLAM3 -- 配置安装
  9. websocket入门案例(echo)
  10. python2和python3并存下的pip使用