Logo Questions Linux Laravel Mysql Ubuntu Git Menu
 

Non-blocking Thrift Server in Python

In below code snippet, I am trying to make a non-blocking thrift server in python.

    # set handler to our implementation
    handler = ServiceHandler()

    processor = MyService.Processor(handler)
    transport = TSocket.TServerSocket(port=port)
    tfactory = TTransport.TFramedTransport(transport)  
    pfactory = TBinaryProtocol.TBinaryProtocolFactory()

    # set server
    server = TServer.TThreadedServer(processor, transport, tfactory, pfactory)

    print 'Python Server has started listening on port ' + str(port)
    print '################################################'
    server.serve()

I am getting the following error when the python client attempts to connect the server having tyhe above code snippet. Could you please tell me what can be causing this error? Probably I am missing something.

    Exception in thread Thread-1:
    Traceback (most recent call last):
    File "/usr/lib64/python2.6/threading.py", line 522, in __bootstrap_inner
    self.run()
    File "/usr/lib64/python2.6/threading.py", line 477, in run
    self.__target(*self.__args, **self.__kwargs)
    File "/usr/local/lib64/python2.6/site-packages/thrift/server/TServer.py", line 114, in handle
    itrans = self.inputTransportFactory.getTransport(client)
    AttributeError: TFramedTransport instance has no attribute 'getTransport'
like image 554
F. Aydemir Avatar asked Dec 05 '11 11:12

F. Aydemir


1 Answers

I found some working Thrift code and it looks like your tfactory needs to be a TBufferedTransportFactory and not a TBufferedTransport instance.

tfactory = TTransport.TBufferedTransportFactory()
like image 70
Andrew Dalke Avatar answered Oct 25 '22 13:10

Andrew Dalke