
Fegin:基于Ribbon和Hystrix声明式服务调用组件 .Feign|OpenFeign 整合了Hystrix,具有熔断降级的能力 .Feign|OpenFeign 整合了Ribbon,具有负载均衡的能力
2.分类: 3.openFeign使用: 引入依赖启动类需要添加@EnableFeignClientsorg.springframework.cloud spring-cloud-starter-openfeign2.2.3.RELEASE
@EnableFeignClients注解告诉框架扫描所有使用注解@FeignClient定义的feign客户端,并把feign客户端注册到IOC容器中。
创建一个接口:// 参数1 value = 模块名
// 参数2 详解在下面
@FeignClient(value = "gp6-lms",contextId = "TrainplanUser")
public interface TrainplanUserClient {
// url含义如下图:
@GetMapping("/gp6/lms/serviceApi/trainplanUser/getByUserIdPlanId")
TrainplanUserDto getByUserIdPlanId(@RequestParam("userId") String userId,
@RequestParam("planId") String planId,
@RequestParam("platformId") String platformId);
// 需要被调用的方法
@PostMapping("/gp6/lms/serviceApi/trainplanUser/addActivateTrainplanForOrderNo")
String addActivateTrainplanForOrderNo(@RequestParam("platformId") String platformId,
@RequestBody TrainplanDto trainplanDto,
@RequestParam("userId") String userId,
@RequestParam("userName") String userName,
@RequestParam("resourceId") String resourceId);
}
contextId的作用
一个模块中被调用的方法个数很多,我们不想都放在一个类中,可以创建多个类。
但是这时候会报错,因为Bean的名称冲突了。
The bean 'gp6-lms.FeignClientSpecification' could not be registered. A bean with that name has already been defined and overriding is disabled.
可以通过指定不同的contextId,来避免这个问题。可以通过 *** 作的类名,来定义contextId。
服务间调用:调用者:special模块,被调用者:lms模块
trainplanUserClient.getByUserIdPlanId(studentVO.getApplyId(),studentVO.getTrainplanId(),platformId);
欢迎分享,转载请注明来源:内存溢出
微信扫一扫
支付宝扫一扫
评论列表(0条)