服務提供者,是位於其餘項目裏面的。
服務提供者提供的方法,在Controller層裏面,有可訪問的Url。html
@Controller @RequestMapping("/order") public class OrderDetailController { @ResponseBody @RequestMapping(value="/detail/cdkey",method=RequestMethod.POST) public OrderDetail getOrderDetailByCdkey(@RequestParam("cdkey") String cdkey){ //其餘邏輯忽略 } }
@FeignClient裏面的value爲服務提供者的服務名,fallback爲服務熔斷的class。
@RequestMapping的value屬性爲服務提供者的Url。json
@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傳遞對象,好比app
@RequestMapping(value="order/detail/cdkey",method=RequestMethod.POST) JSONObject getOrderDetailByCdkey(@RequestBody User user);
若是須要使用佔位符,也能夠用@PathVariable,示例以下:ide
@RequestMapping(value = "/get/{id}", method = RequestMethod.GET) Result get(@PathVariable("id") Integer id);
注意,最好讓方法參數註解和服務提供者的方法參數註解保持一致。微服務
出現異常,能夠經過熔斷保護服務。
熔斷器要實現Feign接口。還要加上註解@Component。code
@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; } }
能夠在其餘類(Service或Controller均可以)中注入已經聲明的Feign接口,並調用其中的方法。
注入方式以下所示:htm
@Autowired private OrderDetailService OrderDetailService;
使用服務中的方法:對象
//調用訂單詳情服務,獲取訂單日期 JSONObject jsonObject=orcmOrderDetailService.getOrderDetailByCdkey(cdkey);
若是在使用Feign進行服務消費時出錯,能夠參考如下內容進行排錯:
微服務SpringCloud沒法進行服務消費
Spring Cloud Feign踩坑記錄(二)blog