SpringCloud Feign 經常使用代碼

服務提供者

服務提供者,是位於其餘項目裏面的。
服務提供者提供的方法,在Controller層裏面,有可訪問的Url。html

@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。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;
    }

}

使用Feign服務接口

能夠在其餘類(Service或Controller均可以)中注入已經聲明的Feign接口,並調用其中的方法。
注入方式以下所示:htm

@Autowired
    private OrderDetailService OrderDetailService;

使用服務中的方法:對象

//調用訂單詳情服務,獲取訂單日期
        JSONObject jsonObject=orcmOrderDetailService.getOrderDetailByCdkey(cdkey);

若是在使用Feign進行服務消費時出錯,能夠參考如下內容進行排錯:
微服務SpringCloud沒法進行服務消費
Spring Cloud Feign踩坑記錄(二)blog

相關文章
相關標籤/搜索