java 单机接口限流处理方案
980
2022-10-17
Feign调用服务各种坑的处理方案
1.编写被调用服务
@RefreshScope
@RestController
public class XXXController extends BaseController implements IndicatorsFeignApi{
@Resource
private XXXService xxx;
@Override
public Wrapper
try {
CommonVo vo = xxx.getdata(commonDto);
return WrapMapper.ok(vo);
}catch(Exception e) {
e.printStackTrace();
return WrapMapper.error("系统异常,请联系管理员!");
}
}
}
//Service不进行展示,注意参数传递至service层时要加入注解@RequestBody等才能获取参数
在配置文件添加feign相关配置
2.编写调用api
pom文件中添加相关依赖
org.springframework.cloud
spring-cloud-starter-hystrix
org.springframework.cloud
spring-cloud-starter-netflix-hystrix-dashboard
调用Api
@FeignClient(value = "被调用服务名")
public interface IndicatorsFeignApi {
@PostMapping(value = "/api/getXXXX",consumes="application/json", headers = {"Accept=application/json", "Content-Type=application/json"})
Wrapper
}
Feign调用错误处理,发生相关错误是会跳转至fallback处理
@Component
public class IndicatorsFeignApiHystrix implements IndicatorsFeignApi {
@Override
public Wrapper
System.out.println("=====调用服务获数据发生异常======");
return null;
}
}
当启用fallback后,有些报错不会打印在控制台上,这时可以修改配置中的
feign:
hystrix:
enabled: thttp://rue
将enabled改为false,错误发生后将不会跳转fallback。
此处有一个坑,当时调用的时候服务是可以调用成功的,但是有一个报错:
Could not extract response: no suitable HttpMessageConverter found for response type [XXXX] and content type [text/html;charset=UTF-8]
貌似是返回数据的编码与接收实体类不一样,导致报错。加上headers = {"Accept=application/json", "Content-Type=application/json"}解决了相关问题.
3.编写客户端服务
//serviceImp层VMRTlYo
@Autowired
private IndicatorsFeignApi api;//声明调用api
@Override
public CommonVo getXXX(CommonDto commonDto) {
Wrapper
if(result!=null) {
return result.getResult();
}else {
return new CommonVo();
}
}
微服务feign调用两边对象不一致
一开始以为feign调用,两边接收的对象必须一致
再发现两边对象的字段一致即可。
在之后遇到一个问题
A服务 a,b,两个字段+ getC()方法
B服务 a,b字段
出现异常序列化失败-----联想到前端解析json对象的方法,直接在B服务加上c字段,问题解决了...
版权声明:本文内容由网络用户投稿,版权归原作者所有,本站不拥有其著作权,亦不承担相应法律责任。如果您发现本站中有涉嫌抄袭或描述失实的内容,请联系我们jiasou666@gmail.com 处理,核实后本网站将在24小时内删除侵权内容。
发表评论
暂时没有评论,来抢沙发吧~