热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

Python的XMLRPC机制:实现跨进程间、client/server端通信

SimpleXMLRPCServer模块式python语言的一个基于xml格式的进程间通信的基础框架。SimpleXMLRPCServer是一个单线程的服务器,这意味

SimpleXMLRPCServer模块式python语言的一个基于 xml 格式的进程间通信的基础框架。

SimpleXMLRPCServer是一个单线程的服务器,这意味着,如果几个客户端同时发出多个请求,其它的请求就必须等待第一个请求完成以后才 能继续。此处也有一个解决方法。

例子代码如下:

创建一个server端主进程,并且利用一个线程开启一个server线程,并开启一个client进程作为child 进程。

MyRemoteService包含三个serveice服务方法,我们测试Add方法,从server端返回计算结果。

#-*- coding: UTF-8 -*-import wx
import threading
import sys
from SimpleXMLRPCServer import SimpleXMLRPCServerclass XMLRPCServerThread(threading.Thread):def __init__(self, remoteServiceInstance, host='127.0.0.1', port=1234):self._RemoteServiceInstance = remoteServiceInstanceself._Host = hostself._Port = portthreading.Thread.__init__(self)def stop(self):self._Server.shutdown() def run(self):self._Server = SimpleXMLRPCServer( (self._Host, self._Port), logRequests=False, allow_none = True )self._Server.register_instance( self._RemoteServiceInstance )self._Server.serve_forever()class MyRemoteService(object):def __init__(self, obj):self.obj = objdef Add(self, a, b):return a + bdef NoReturn(self):print 'xxxx'def Empty(self):return u'中国 .'class MyFrame(wx.Frame):def __init__(self, parent):wx.Frame.__init__(self, parent, -1, "Server service")mainPanel = wx.Panel(self, size = (300, 400))mainPanel.SetBackgroundColour(wx.Colour(0,122,200))sizer = wx.BoxSizer(wx.VERTICAL)sizer.Add(mainPanel, 1, wx.EXPAND)self.SetSizerAndFit(sizer)## @detail ShellApp主应用程序的核
class ShellApp(wx.App):def OnInit(self):mainFrame = MyFrame(None)self.Bind(wx.EVT_END_PROCESS, self.OnProcessEnded)self.__ServerThread = self.__GetRPCThread()self.__ChildProcess = wx.Process(self)pid = wx.Execute('python remoteClient.py', wx.EXEC_NOHIDE|wx.EXEC_ASYNC, self.__ChildProcess) mainFrame.Show(True) return Truedef __GetRPCThread(self, host='localhost', port=1234):remoteObj = MyRemoteService(self)rpcThread = XMLRPCServerThread(remoteObj, host, port)rpcThread.start()return rpcThreaddef OnProcessEnded(self, evt):print 'Child process exist'self.__ChildProcess.Destroy()self.__ServerThread.stop()self.Exit()# @detail main程序的主入口程序
if __name__ == '__main__': app = ShellApp()#重新定向wxpython的输出输入和错误输出到系统标准输入输出sys.stdin = sys.__stdin__sys.stdout = sys.__stdout__sys.stderr = sys.__stderr__app.MainLoop()

client端代码如下:

#-*- coding: UTF-8 -*-
import wx
import sys
import xmlrpclib #客户端from SimpleXMLRPCServer import SimpleXMLRPCServerclass MyFrame(wx.Frame):def __init__(self, parent):wx.Frame.__init__(self, parent, -1, "Client app")mainPanel = wx.Panel(self, size = (300, 200))addButton = wx.Button(mainPanel, -1, 'Add')addButton.Bind(wx.EVT_BUTTON, self.__OnAddClicked)self._AText = wx.TextCtrl(mainPanel, -1, '10')self._AddText = wx.StaticText(mainPanel, -1, ' + ')self._BText = wx.TextCtrl(mainPanel, -1, '23')self._Label = wx.StaticText(self, -1, ' = ')self._SumText = wx.TextCtrl(mainPanel)panelSizer = wx.BoxSizer(wx.HORIZONTAL)panelSizer.Add(addButton, 0, wx.ALL, 6) panelSizer.Add(self._AText, 0, wx.ALL, 6)panelSizer.Add(self._AddText, 0, wx.ALL, 6)panelSizer.Add(self._BText, 0, wx.ALL, 6)panelSizer.Add(self._Label, 0, wx.ALL, 6)panelSizer.Add(self._SumText, 0, wx.ALL, 6)mainPanel.SetSizer(panelSizer)mainPanel.SetBackgroundColour(wx.Colour(122,12,20))sizer = wx.BoxSizer(wx.VERTICAL)sizer.Add(mainPanel, 1, wx.EXPAND)self.SetSizerAndFit(sizer)self._Proxy = xmlrpclib.ServerProxy('http://127.0.0.1:1234') def __OnAddClicked(self, evt):a = int(self._AText.GetLabel())b = int(self._BText.GetLabel())sum = self._Proxy.Add(a, b)self._SumText.SetLabel('%s'%sum)self._Proxy.NoReturn()## @detail ShellApp主应用程序的核
class ShellApp(wx.App): def OnInit(self):mainFrame = MyFrame(None)mainFrame.Show(True) return True# @detail main程序的主入口程序
if __name__ == '__main__': app = ShellApp()#重新定向wxpython的输出输入和错误输出到系统标准输入输出sys.stdin = sys.__stdin__sys.stdout = sys.__stdout__sys.stderr = sys.__stderr__app.MainLoop()

运行结果如下:

 

 

转:https://www.cnblogs.com/ankier/p/3231288.html



推荐阅读
  • 深入解析Spring Cloud Ribbon负载均衡机制
    本文详细介绍了Spring Cloud中的Ribbon组件如何实现服务调用的负载均衡。通过分析其工作原理、源码结构及配置方式,帮助读者理解Ribbon在分布式系统中的重要作用。 ... [详细]
  • 本文介绍了ArcXML配置文件的分类及其在不同服务中的应用,详细解释了地图配置文件的结构和功能,包括其在Image Service、Feature Service以及ArcMap Server中的使用方法。 ... [详细]
  • 阿里云ecs怎么配置php环境,阿里云ecs配置选择 ... [详细]
  • 远程过程调用(RPC)是一种允许客户端通过网络请求服务器执行特定功能的技术。它简化了分布式系统的交互,使开发者可以像调用本地函数一样调用远程服务,并获得返回结果。本文将深入探讨RPC的工作原理、发展历程及其在现代技术中的应用。 ... [详细]
  • NFS(Network File System)即网络文件系统,是一种分布式文件系统协议,主要用于Unix和类Unix系统之间的文件共享。本文详细介绍NFS的配置文件/etc/exports和相关服务配置,帮助读者理解如何在Linux环境中配置NFS客户端。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文详细介绍了如何使用PHP检测AJAX请求,通过分析预定义服务器变量来判断请求是否来自XMLHttpRequest。此方法简单实用,适用于各种Web开发场景。 ... [详细]
  • 本文详细介绍如何使用Samba软件配置CIFS文件共享服务,涵盖安装、配置、权限管理及多用户挂载等关键步骤。通过具体示例和命令行操作,帮助读者快速搭建并优化Samba服务器。 ... [详细]
  • 解决JAX-WS动态客户端工厂弃用问题并迁移到XFire
    在处理Java项目中的JAR包冲突时,我们遇到了JaxWsDynamicClientFactory被弃用的问题,并成功将其迁移到org.codehaus.xfire.client。本文详细介绍了这一过程及解决方案。 ... [详细]
  • 优化局域网SSH连接延迟问题的解决方案
    本文介绍了解决局域网内SSH连接到服务器时出现长时间等待问题的方法。通过调整配置和优化网络设置,可以显著缩短SSH连接的时间。 ... [详细]
  • 本文详细介绍了Java Web应用程序中的过滤器(Filter)功能,包括其作用、实现方式及配置方法。过滤器可以在请求到达目标资源之前对其进行预处理,并在响应返回给客户端之前进行后处理。 ... [详细]
  • 本文详细介绍了网络存储技术的基本概念、分类及应用场景。通过分析直连式存储(DAS)、网络附加存储(NAS)和存储区域网络(SAN)的特点,帮助读者理解不同存储方式的优势与局限性。 ... [详细]
  • 本文详细介绍如何利用已搭建的LAMP(Linux、Apache、MySQL、PHP)环境,快速创建一个基于WordPress的内容管理系统(CMS)。WordPress是一款流行的开源博客平台,适用于个人或小型团队使用。 ... [详细]
  • 本文探讨了Web开发与游戏开发之间的主要区别,旨在帮助开发者更好地理解两种开发领域的特性和需求。文章基于作者的实际经验和网络资料整理而成。 ... [详细]
  • MySQL 数据库迁移指南:从本地到远程及磁盘间迁移
    本文详细介绍了如何在不同场景下进行 MySQL 数据库的迁移,包括从一个硬盘迁移到另一个硬盘、从一台计算机迁移到另一台计算机,以及解决迁移过程中可能遇到的问题。 ... [详细]
author-avatar
mobiledu2502925953
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有