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踩坑记录(二)
SpringCloud Feign 常用代码的更多相关文章
- SpringCloud+Feign环境下文件上传与form-data同时存在的解决办法(2)
书接上文. 上文中描述了如何在 SpringCloud+Feign环境下上传文件与form-data同时存在的解决办法,实践证明基本可行,但却会引入其他问题. 主要导致的后果是: 1. 无法与普通Fe ...
- SpringCloud Feign 之 Fallback初体验
SpringCloud Feign 之 Fallback初体验 在微服务框架SpringCloud中,Feign是其中非常重要且常用的组件.Feign是声明式,模板化的HTTP客户端,可以帮助我们更方 ...
- SpringCloud Feign通过FallbackFactory显示异常信息
SpringCloud Feign可以进行服务消费,而且内置了Hystrix,能够进行熔断. Feign可以通过fallback指定熔断回调的类.代码示例及讲解可见: https://www.cnbl ...
- GCD 常用代码
GCD 常用代码 体验代码 异步执行任务 - (void)gcdDemo1 { // 1. 全局队列 dispatch_queue_t q = dispatch_get_global_queue(0, ...
- 转--Android实用的代码片段 常用代码总结
这篇文章主要介绍了Android实用的代码片段 常用代码总结,需要的朋友可以参考下 1:查看是否有存储卡插入 复制代码 代码如下: String status=Environment.getE ...
- 刀哥多线程之03GCD 常用代码
GCD 常用代码 体验代码 异步执行任务 - (void)gcdDemo1 { // 1. 全局队列 dispatch_queue_t q = dispatch_get_global_queue(0, ...
- jquery常用代码集锦
1. 如何修改jquery默认编码(例如默认GB2312改成 UTF-8 ) 1 2 3 4 5 $.ajaxSetup({ ajaxSettings : { contentT ...
- Mysql:常用代码
C/S: Client Server B/S: Brower Server Php主要实现B/S .net IIS Jave TomCat LAMP:L Mysql:常用代码 Create table ...
- javascript常用代码大全
http://caibaojian.com/288.html 原文链接 jquery选中radio //如果之前有选中的,则把选中radio取消掉 $("#tj_cat .pro_ca ...
随机推荐
- 解决for循环中异步处理(异步变同步)
前沿:参考ES6语法的async/await的处理机制 先上一段代码 function getMoney(){ var money=[100,200,300] for( let i=0; i<m ...
- 如何解决NoSuchMethodError
背景 工作中写单测,本来用的Mockito,但是为了mock方法里调用的其他静态方法,所以需要使用powermock,于是开始报错. 我把包引入了,然后照着网上的写单测代码,写完了之后运行.噩梦开始. ...
- VUE基础回顾6
1.ref ref可以直接访问元素,而不需要使用querySelector或者其他dom节点的原生方法. <div ref = "box"></div> 在 ...
- IntelliJ IDEA 快捷键(转载收藏)
自动代码 常用的有fori/sout/psvm+Tab即可生成循环.System.out.main方法等boilerplate样板代码 . 例如要输入for(User user : users)只需输 ...
- 《我是一只IT小小鸟》(续)读书笔记——第八周
第三位作者强调了大学阶段规划的重要性,作者初入大学,一切都很新鲜想尝试,却缺乏对学习生活的规划.最终导致的是学习成绩的下降.其实编程也是一样,我们常常感到自己和那些大神的差距,感慨过后,往往也就罢了. ...
- PHP实现财务审核通过后返现金额到客户
应用场景: 有这么一个返现的系统,当前端客户发起提现的时候,后端就要通过审核这笔返现订单,才可以返现到客户的账号里. 来看看下面的截图 这里的业务场景就是经过两轮审核:销售审核,财务审核都通过后,后端 ...
- githe和github连接,上传
Git入门 如果你完全没有接触过Git,你现在只需要理解通过Git的语法(敲入一些命令)就可以将代码上传到远程的仓库或者下载到本地的仓库(服务器),可知我们此时应该有两个仓库,就是两个放代码的地方,一 ...
- MySQL Replication--事务组提交和多线程复制
事务组提交和多线程复制 在MySQL 5.7版本引入基于LOGICAL_CLOCK的多线程复制,依赖于BINLOG事件中的last_committed属性,该last_committed属性是否与事务 ...
- centos7修改IP地址(静态)
环境如下: 操作系统: CentOS-7-x86_64-DVD-1908.iso 步骤如下: 1. 查看网卡信息 ip a 2.编辑对应网卡的配置文件,我这里网卡是ens33,所以我修改的是文件 i ...
- spring cloud turbine 监控不到其它机器上的hystrix.stream 的解决方法 指定监控ip
turbine多台机器熔断聚合的时候 turbine控制台一直寻找的是localhost下的监控熔断数据. c.n.t.monitor.instance.InstanceMonitor : Ur ...