最近在项目中采用thrift作为后台服务rpc框架,总体用下来性能还不错,跨语言特性使用起来也还行,但是也遇到了一些坑,其中之一就是超时问题(timeout),如果服务端些的某些业务场景耗时较长,thrift client几乎毫无意外的会遇到:Read timed out, 当然解决办法也很容易,thrift client端手动设置一个较长的超时时间即可。

下面才是真正吐槽的开始:

既然号称跨语言,至少各个语言在实现底层功能时,API应该保持一致吧,比如java中的有一个XXXTimeout的属性,php中应该也有这个属性吧,然而并不是这样的,不仅超时设置的方法名(属性名)不同,连TMD的时间单位都不一致。

而且这种问题,几乎在网上也查不到资料,只能查看源码,在thrift源码(目前最新的是0.9.3)的lib包下,有名种语言的实现,可以找几个来瞅瞅:

php版:

文件位置:thrift-0.9.3/lib/php/lib/Thrift/Transport/TSocket.php

  1. /**
  2. * Send timeout in seconds.
  3. *
  4. * Combined with sendTimeoutUsec this is used for send timeouts.
  5. *
  6. * @var int
  7. */
  8. private $sendTimeoutSec_ = 0;
  9.  
  10. /**
  11. * Send timeout in microseconds.
  12. *
  13. * Combined with sendTimeoutSec this is used for send timeouts.
  14. *
  15. * @var int
  16. */
  17. private $sendTimeoutUsec_ = 100000;
  18.  
  19. /**
  20. * Recv timeout in seconds
  21. *
  22. * Combined with recvTimeoutUsec this is used for recv timeouts.
  23. *
  24. * @var int
  25. */
  26. private $recvTimeoutSec_ = 0;
  27.  
  28. /**
  29. * Recv timeout in microseconds
  30. *
  31. * Combined with recvTimeoutSec this is used for recv timeouts.
  32. *
  33. * @var int
  34. */
  35. private $recvTimeoutUsec_ = 750000;

在php中,是通过设置sendTimeout及recvTimeout来影响超时的,而且从注释中的单词microseconds可以看出,时间单位为『微秒』,但同样在这个文件中,继续向下看,

  1. /**
  2. * Sets the send timeout.
  3. *
  4. * @param int $timeout Timeout in milliseconds.
  5. */
  6. public function setSendTimeout($timeout)
  7. {
  8. $this->sendTimeoutSec_ = floor($timeout / 1000);
  9. $this->sendTimeoutUsec_ =
  10. ($timeout - ($this->sendTimeoutSec_ * 1000)) * 1000;
  11. }
  12.  
  13. /**
  14. * Sets the receive timeout.
  15. *
  16. * @param int $timeout Timeout in milliseconds.
  17. */
  18. public function setRecvTimeout($timeout)
  19. {
  20. $this->recvTimeoutSec_ = floor($timeout / 1000);
  21. $this->recvTimeoutUsec_ =
  22. ($timeout - ($this->recvTimeoutSec_ * 1000)) * 1000;
  23. }

到了真正设置的地方,按注释上的描述,又换成了milliseconds(毫秒),不明白为啥要这么折腾,php不太懂,根据http://blog.csdn.net/zf2371752658/article/details/40148399 这篇文章中的1楼回复来看,正确的理解应该是微秒。

c#版:

文件位置:thrift-0.9.3/lib/csharp/src/Transport/TSocket.cs

  1. public int Timeout
  2. {
  3. set
  4. {
  5. client.ReceiveTimeout = client.SendTimeout = timeout = value;
  6. }
  7. }

干脆就全统一成Timeout这一个属性了,而且没给任何注释说明什么时间单位。

java版:

文件位置:thrift-0.9.3/lib/java/src/org/apache/thrift/transport/TSocket.java

  1. /**
  2. * Sets the socket timeout and connection timeout.
  3. *
  4. * @param timeout Milliseconds timeout
  5. */
  6. public void setTimeout(int timeout) {
  7. this.setConnectTimeout(timeout);
  8. this.setSocketTimeout(timeout);
  9. }
  10.  
  11. /**
  12. * Sets the time after which the connection attempt will time out
  13. *
  14. * @param timeout Milliseconds timeout
  15. */
  16. public void setConnectTimeout(int timeout) {
  17. connectTimeout_ = timeout;
  18. }
  19.  
  20. /**
  21. * Sets the socket timeout
  22. *
  23. * @param timeout Milliseconds timeout
  24. */
  25. public void setSocketTimeout(int timeout) {
  26. socketTimeout_ = timeout;
  27. try {
  28. socket_.setSoTimeout(timeout);
  29. } catch (SocketException sx) {
  30. LOGGER.warn("Could not set socket timeout.", sx);
  31. }
  32. }

又拆成了3个成员:Timeout,ConnectTimeout,SocketTimeout了,时间单位从注释上看,是毫秒。

js版:(你没有看错,thrift client还支持node js/javascript)

文件位置:thrift-0.9.3/lib/js/src/thrift.js

通篇全文查找,也没到关于"timeout"的内容

个人猜测:造成这种乱象的原因是不同语言的客户端实现,是由不同团队完成的,每个团队各自为阵,没有一个上层的牵头人来强制约束API规范。

结论:thrift很强大,也很成熟,但是好用的文档并不多,如果在项目中遇到问题,求人不如求已,除了啃源码,还是啃源码。

thrift中的超时(timeout)坑的更多相关文章

  1. 如何解决python中urlopen超时问题

    看代码: 利用urlopen中的超时参数设立一个循环 while True: try: page = urllib.request.urlopen(url, timeout=3) break exce ...

  2. 记一次SpringBoot 开发中所遇到的坑和解决方法

    记一次SpringBoot 开发中所遇到的坑和解决方法 mybatis返回Integer为0,自动转型出现空指针异常 当我们使用Integer去接受数据库中表的数据,如果返回的数据中为0,那么Inte ...

  3. axios超时timeout拦截

    应用场景: 在网络请求中,可能不可避免的会遇到网络差或者请求超时的情况,这时候,如果你采用的技术是axios,那就可以通过设置拦截器捕获这个异常情况,并做出下一步处理. 代码实践: ① 设置拦截器,返 ...

  4. 记录vue中一些有意思的坑

    记录vue中一些有意思的坑 'message' handler took 401ms 在出现这个之前,我一直纠结于 是如何使用vue-router或者不使用它,通过类似的v-if来实现.结果却出现这个 ...

  5. 项目中踩过的坑之-sessionStorage

    总想写点什么,却不知道从何写起,那就从项目中踩过的坑开始吧,希望能给可能碰到相同问题的小伙伴一点帮助. 项目情景: 有一个id,要求通过当前网页打开一个新页面(不是当前页面),并把id传给打开的新页面 ...

  6. 使用ffmpeg视频编码过程中踩的一个坑

           今天说说使用ffmpeg在写视频编码程序中踩的一个坑,这个坑让我花了好多时间,回头想想,非常多时候一旦思维定势真的挺难突破的.以下是不对的编码结果:                   ...

  7. 从mina中学习超时程序编写

    从mina中学习超时程序编写 在很多情况下,程序需要使用计时器定,在指定的时间内检查连接过期.例如,要实现一个mqtt服务,为了保证QOS,在服务端发送消息后,需要等待客户端的ack,确保客户端接收到 ...

  8. 细数Python Flask微信公众号开发中遇到的那些坑

    最近两三个月的时间,断断续续边学边做完成了一个微信公众号页面的开发工作.这是一个快递系统,主要功能有用户管理.寄收件地址管理.用户下单,订单管理,订单查询及一些宣传页面等.本文主要细数下开发过程中遇到 ...

  9. 小程序中曾经遇到的坑(1)----canvas画布

    目前正在开发小程序,在开发过程中,总会遇到一些坑,而这些坑并不会有很多开发者遇到而说出来.这里先记录一条我开发过程中遇到的问题,以便后人在开发中能够更容易的解决问题!!! 首先,小程序在canvas画 ...

随机推荐

  1. 【工业串口和网络软件通讯平台(SuperIO)教程】五.二次开发图形显示界面

    SuperIO相关资料下载:http://pan.baidu.com/s/1pJ7lZWf 1.1    图形显示接口的作用 用于显示采集终端设备的数据,可以把不同类型设备的数据以多种形式集成显示在不 ...

  2. SpringMVC处理客户端请求的过程

    SpringMVC处理客户端请求的过程 以程序部署在Tomcat上为例,网站程序使用SpringMVC框架开发. 1.客户端发起一个访问网站的请求(如: localhost:8080/index). ...

  3. Elasticsearch索引(company)_Centos下CURL增删改

    目录 返回目录:http://www.cnblogs.com/hanyinglong/p/5464604.html 1.Elasticsearch索引说明 a. 通过上面几篇博客已经将Elastics ...

  4. c/C++二进制运算符

    c/c++中常用的二进制运算符有六个.这里对这六个做简单的介绍和应用举例. 1.  &  :  与操作.作用于两个二进制数,当然也可以对整型数据进行操作(当两边为整型数据会自动转化为二进制数) ...

  5. 原生JS:JSON对象详解

    JSON对象 支持到IE8,旧版的IE需要Polyfill 本文参考MDN做的详细整理,方便大家参考[MDN](https://developer.mozilla.org/zh-CN/docs/Web ...

  6. JavaScript-数组去重由慢到快由繁到简

    indexOf去重 Array.prototype.unique1 = function() { var arr = []; for (var i = 0; i < this.length; i ...

  7. 屌丝giser成长记-研一篇(上)

    2011年本科毕业之后,我选择了保研GIS研究生,继续了我的GIS研究生涯,读研的童鞋们注意了,读研选择什么样的导师很重要,因为不同的导师有不同的人脉,从浅一点的来说,导师手头的开发项目多的话,你自己 ...

  8. Java泛型介绍——HashMap总结

    今天在编程中,需要使用到Hashmap来存储和传递数据,发现自己学习Java这么久,实际上对泛型依旧知之甚少,搜索整理了一下HashMap的使用. HashMap的声明初始化,因为泛型的原因,起两个参 ...

  9. Snort 安装 配置 - Archlinux

    About Snort Snort是一套开放源代码(OpenSource and free)的网络入侵预防软件(NIPS)与网络入侵检测软件(NIDS).Snort使用了以侦测签名(signature ...

  10. RoboGuice 3.0 (二)进阶篇

    上篇介绍了RoboGuice的接入及基本使用,其中涉及到了一个@Singleton和@ContextSingleton的注解,这些都是作用域的注解,这篇我们先说明有关作用域的问题. 一.作用域 Sco ...