使用Thrift让Python为Java提供服务

Thrift是基于TCP的,谷歌的GRPC是基于HTTP的。Thrift和GRPC都是比直接写个web接口进行调用更完美的方式,最明显的一点就是:我们可以定义结构体,避免了手动解析的过程。

但是,在将Python作为Thrift服务端,Java作为客户端时,有一个天坑:始终都是connection refused。

windows下查看端口占用:netstat -aon|findstr "8091"。会发现服务正常启动了。
然而多次运行python服务端,竟然不报“端口已占用”的错误。

错误原因是:Python使用了TCPV6,Java使用的是TCP。
改成127.0.0.1解决问题,看来以后再也不要用localhost了,一律使用127.0.0.1

Python:  transport = TSocket.TServerSocket(host="127.0.0.1", port = 9091)
Java:  transport = new TSocket("127.0.0.1", 9091);

参考资料
https://stackoverflow.com/questions/16760741/apache-thrift-python-java-connection-refused

猜你喜欢

转载自www.cnblogs.com/weiyinfu/p/10022596.html