Workman-Thrift疑问解析
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在服务满载的情况下无法重入)
本文档会随着学习,不断完善。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· .NET10 - 预览版1新功能体验(一)