超时时间的用途的理解和总结

来源:互联网 发布:get软件买到假鞋 编辑:程序博客网 时间:2024/06/05 13:21

1.经典场景:网络下的调用

在网络下的调用,比如RPC调用,一个调用都是要提供超时时间的,对于这个超时时间,我们从以下几个问题来理解和关注;

1.为什么要有超时时间

这个是因为各种不确定性的因素导致调用时间的不确定性,这个时间的存在用以表示调用端预期的时间,超过这个时间,调用端就知道接下来该怎么做,调用端可以做一些相应的处理。
超时时间是一个(客户端自己的)协调时间;

2. 超时前后

一端调用另外一端,在超时时间内返回了结果,这是一个正常的情况,
如果超时了,那么调用端就可能做相应的处理(比如(延时)重试等);

3. 谁来决定超时以及超时后,两端的反应是什么

一端调用另外一端(通过网络的调用),如果A设置超时时间,而且调用超时,那么A可以采取一些策略来应对这种情况,但是有一个问题需要关注和考虑:就是另外一端B的逻辑可能还在执行,那么B怎么办(是继续执行还是中断)?

0 0