服务提供者
服务提供者,是位于其他项目里面的。
服务提供者提供的方法,在Controller层里面,有可访问的Url。
@Controller
@RequestMapping("/order")
public class OrderDetailController {
@ResponseBody
@RequestMapping(value="/detail/cdkey",method=RequestMethod.POST)
public OrderDetail getOrderDetailByCdkey(@RequestParam("cdkey") String cdkey){
//其他逻辑忽略
}
}
服务消费者Feign
@FeignClient里面的value为服务提供者的服务名,fallback为服务熔断的class。
@RequestMapping的value属性为服务提供者的Url。
@FeignClient(value = "base",fallback = OrderDetailHystrix.class)
public interface OrderDetailService {
@RequestMapping(value="order/detail/cdkey",method=RequestMethod.POST)
JSONObject getOrderDetailByCdkey(@RequestParam("cdkey") String cdkey);
}
除了使用如上的@RequestParam,还可以使用@RequestBody传递对象,比如
@RequestMapping(value="order/detail/cdkey",method=RequestMethod.POST)
JSONObject getOrderDetailByCdkey(@RequestBody User user);
如果需要使用占位符,也可以用@PathVariable,示例如下:
@RequestMapping(value = "/get/{id}", method = RequestMethod.GET)
Result get(@PathVariable("id") Integer id);
注意,最好让方法参数注解和服务提供者的方法参数注解保持一致。
服务熔断
出现异常,可以通过熔断保护服务。
熔断器要实现Feign接口。还要加上注解@Component。
@Component
public class OrderDetailHystrix implements OrderDetailService {
@Override
public JSONObject getOrderDetailByCdkey(String cdkey) {
JSONObject resultJson = new JSONObject();
resultJson.put("errcode",AUTH_ORDER_SERVICE_ERROR.getCode() );
resultJson.put("description", AUTH_ORDER_SERVICE_ERROR.getMsg() );
return resultJson;
}
}
使用Feign服务接口
可以在其他类(Service或Controller都可以)中注入已经声明的Feign接口,并调用其中的方法。
注入方式如下所示:
@Autowired
private OrderDetailService OrderDetailService;
使用服务中的方法:
//调用订单详情服务,获取订单日期
JSONObject jsonObject=orcmOrderDetailService.getOrderDetailByCdkey(cdkey);
如果在使用Feign进行服务消费时出错,可以参考以下内容进行排错:
微服务SpringCloud无法进行服务消费
Spring Cloud Feign踩坑记录(二)