我一直在尝试在C中实现一个节俭服务器以与Python客户端进行通信.
这是我的代码:
C服务器:
shared_ptr<ThriftHandler> _handler (new myHandler());
shared_ptr<TProcessor> _processor (new myService(_handler));
shared_ptr<TProtocolFactory> _protocolFactory (new TBinaryProtocolFactory());
shared_ptr<ThreadManager> _threadManager = ThreadManager::newSimpleThreadManager(15);
shared_ptr<PosixThreadFactory> _threadFactory(new PosixThreadFactory());
_threadManager->threadFactory(_threadFactory);
_threadManager->start();
shared_ptr<TNonblockingServer> _server(new TNonblockingServer(_processor, _protocolFactory, 9090 ,_threadManager));;
_server->serve();
Python客户端代码:
transport = TSocket.TSocket(host, port)
transport = TTransport.TFramedTransport(transport)
protocol = TBinaryProtocol.TBinaryProtocol(transport)
client = MyService.Client(protocol)
transport.open()
log.info("connection success!")
当我启动服务器然后启动客户端时,我得到以下信息:
在客户端(Python):
./myPythonExec.py
connection success!
socket.error: [Errno 104] Connection reset by peer
在服务器端(c):
assertion " 0 " failed
0 0x00007ffff0942425 in __GI_raise (sig=<optimized out>) at ../nptl/sysdeps/unix/sysv/linux/raise.c:64
1 0x00007ffff0945b8b in __GI_abort () at abort.c:91
2 0x00007ffff093b0ee in __assert_fail_base (fmt=<optimized out>, assertion=0x7ffff1438f1a "0",
file=0x7ffff1439298 "src/server/TNonblockingServer.cpp", line=<optimized out>, function=<optimized out>) at assert.c:94
3 0x00007ffff093b192 in __GI___assert_fail (assertion=0x7ffff1438f1a "0", file=0x7ffff1439298 "src/server/TNonblockingServer.cpp",
line=558, function=0x7ffff1439c60 "void apache::thrift::server::TNonblockingServer::TConnection::workSocket()") at assert.c:103
4 0x00007ffff14336e4 in apache::thrift::server::TNonblockingServer::TConnection::workSocket (this=0x7fffc0004ac0)
at src/server/TNonblockingServer.cpp:558
5 0x00007ffff11ed94c in event_base_loop () from /usr/lib/libevent-2.0.so.5
我正在使用libthrift 0.8.0,并且与libthrift 0.9.1具有相同的pb
当在C上使用TSimpleServer并在客户端上使用TBufferedTransport时,它可以完美地工作
解决方法:
抱歉,之前没有见过,但是看起来像是同一问题:
Service Multiplexing using Apache Thrift
简而言之,您必须使用两面都没有框的框架,也可以不使用.
shared_ptr<TTransportFactory> _transportFactory(new TFramedTransportFactory());
shared_ptr<TNonblockingServer> _server(
new TNonblockingServer(
_processor,
_transportFactory,
_transportFactory,
_protocolFactory,
_protocolFactory,
9090,
_threadManager));
_server->serve();