首页 > 其他 > 详细

Workman-Thrift疑问解析

时间:2017-10-19 18:57:29      阅读:222      评论:0      收藏:0      [点我收藏+]

    Workman是纯纯的PHP实现的一套网络通信框架,Workman-Thrift则是以Workman为基础,为Thrift RPC实现网络通信。经过学习与测试,现把自己的疑问与验证记录下来:

 

问题一:用Trift-0.9.3的源码包中的php库替换Workman-Thrift的Thrift库之后,当Handler处理过程中遇到耗时的操作(可用sleep进行模拟),就会报出未被捕获的异常。但是,用Workman-Thrift自带的旧Thrift库就不会有这个问题 。

原因:因为旧库的网络发送/读取的超时时间被修改过,新库覆盖过之后,只要修改/Application/ThriftRpc/Lib/Thrift/Transport/TSocket.php文件第64和82行,分别将发送和读取时间改为3秒(按实际情况进行修改)即可。

 

问题二:当worker进程与请求数量一致时,即通信满载,之后发起请求的进程会发生什么情况?

实验结果:在worker进程服务完成之前,之后发起请求的进程会进行等待,直到有空闲的worker进程或者客户端请求超时。要注意:即使worker进程转为空闲状态,此时有很大的概率会服务超时。(即Handler在服务满载的情况下无法重入)

 

 

本文档会随着学习,不断完善。

Workman-Thrift疑问解析

原文:http://www.cnblogs.com/ddcoder/p/7694124.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!