SpringCloud Feign 常用代码

服务提供者

服务提供者,是位于其他项目里面的。
服务提供者提供的方法,在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踩坑记录(二)

你可能感兴趣的:(feign,spring,cloud,java,spring,boot)