thrift双向通信实现时客户端报:“apache::thrift::transport::TTransportExce what(): Frame size has negative value”

在将Thrift从单向通信改为双向通信的过程中,遇到客户端报'apache::thrift::transport::TTransportException: Frame size has negative value'的异常。问题源于服务端使用了TNonblockingServer和TframedTransport,导致服务端调用客户端接口时出错。解决方案是服务端改用TThreadedServer或TThreadPoolServer,客户端使用TBufferedTransport。需要注意,TThreadedServer和TThreadPoolServer在高并发时可能导致CPU消耗增加,而TFramedTransport虽然非阻塞但延迟较高。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

    公司的代码之前实现了thrift客户端,服务端单向通信,也就是在一个连接中,只能客户端调用服务端的接口,而服务端不能调用客户端的接口。需要修改为是双向通信,也就是允许服务端主动给客户端发消息,或者说调用客户端的接口。

下面的代码是服务端部分代码:

nbSocket.reset(new transport::TNonblockingServerSocket(port));
serverThread = threadFactory->newThread(stdcxx::shared_ptr<TServer>(
	new TNonblockingServer(getprocessorfactory(johnson, connections), protocolFactory, nbSocket, threadManager)));

服务端使用了TNonblockingServer的服务模型。

再来看一下客户端的连接代码:

stdcxx::shared_ptr<TTransport> socket(new TSocket("localhost", 9091));
stdcxx::shared_ptr<TTransport> transport(new  TFramedTransport(socket));
stdcxx::shared_ptr<TProtocol> protocol(new TBinaryProtocol(transport));

由于服务端使用的服务模型,客户端的数据传输方式只能用TframedTransport。

由此,当服务端调用客户端接口发送数据时就会抛出如下异常:


                
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值