1、先说结论:使用xml-rpc的机制可以很方便的实现服务器间的RPC调用。
2、试验结果如下:
3、源码如下:
服务器端的源代码如下:
import operator,mathfrom SimpleXMLRPCServer import SimpleXMLRPCServerfrom functools import reducedef main(): server = SimpleXMLRPCServer(('127.0.0.1',7001)) server.register_introspection_functions() server.register_multicall_functions() server.register_function(addtogether) server.register_function(quadratic) server.register_function(remote_repr) print("Server ready") server.serve_forever() def addtogether(*things): """Add together everything in the List things .""" return reduce(operator.add,things) def quadratic(a,b,c): """Determine x values satisfying: a * x * x + b * x + c = 0""" b24ac = math.sqrt(b*b - 4.0*a*c) return List(set([(-b-b24ac) / 2.0*a,(-b+b24ac) / 2.0*a])) def remote_repr(arg): """return the repr() rendering of the supplIEd arg """ return arg if __name__ == '__main__': main()
客户端的代码如下:
import xmlrpclibdef main(): proxy = xmlrpclib.ServerProxy('http://127.0.0.1:7001') print("Here are the functions supported by this server:") print("next calculator addtogether: ") print(proxy.addtogether('x','y','z')) print(proxy.addtogether('x','z')) print(proxy.addtogether('x','z')) for method_name in proxy.system.ListMethods(): if method_name.startswith('system.'): continue signatures = proxy.system.methodSignature(method_name) if isinstance(signatures,List) and signatures: for signature in signatures: print('%s(%s)' %(method_name,signature)) else: print('%s(...)' %(method_name,)) method_help = proxy.system.methodHelp(method_name) #if method_help: # print(' ',methodHelp) print(proxy.addtogether('x','z')) print("addtogether result ") if __name__ == '__main__': main()
以上这篇使用XML库的方式,实现RPC通信的方法(推荐)就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持编程小技巧。
总结以上是内存溢出为你收集整理的使用XML库的方式,实现RPC通信的方法(推荐)全部内容,希望文章能够帮你解决使用XML库的方式,实现RPC通信的方法(推荐)所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)