局域網(wǎng)發(fā)布共享文件xml-rpc實(shí)現(xiàn)的文件共享
資料介紹
軟件簡(jiǎn)介
xml-rpc 實(shí)現(xiàn)的文件共享
這個(gè)項(xiàng)目取材與http://www.the5fire.com/python-project8-xml-rpc.html 。是python基礎(chǔ)教程中的十個(gè)例子中的第八個(gè)。主要的實(shí)現(xiàn)原理如下:
每一個(gè)客戶端都是一個(gè)節(jié)點(diǎn)。每一個(gè)節(jié)點(diǎn),都啟動(dòng)一個(gè) xml-rpc服務(wù)器。在 xml-rpc服務(wù)器中,維護(hù)著一個(gè)所有節(jié)點(diǎn)的集合。原文的例子,功能太少,只能下載。后來(lái)我加了一個(gè)ls 命令,可以查看包括自己的和所有節(jié)點(diǎn)的文件。原項(xiàng)目中的節(jié)點(diǎn)列表,必須是手動(dòng)給出的,相當(dāng)麻煩,是通過(guò)一個(gè)叫urlfile的文件來(lái)維護(hù)的。在我的這個(gè)項(xiàng) 目中,維護(hù) 節(jié)點(diǎn)的信息是通過(guò)程序自己學(xué)習(xí)到的。每當(dāng)一個(gè)節(jié)點(diǎn)啟動(dòng)的時(shí)候,該節(jié)點(diǎn)就會(huì)把自己的xml-rpc服務(wù)器的訪問(wèn)url,通過(guò)udp廣播的方式,廣播給某一個(gè) 端口。同時(shí)每一個(gè)節(jié)點(diǎn),只要它啟動(dòng)后,會(huì)監(jiān)聽某一個(gè)端口上的,有關(guān)xml-rpc服務(wù)器的訪問(wèn)url的監(jiān)聽。只要收到信息,就把它寫入到節(jié)點(diǎn)列表中。通過(guò) fetch下載文件時(shí),如果發(fā)現(xiàn)了異常,則從節(jié)點(diǎn)列表中刪除它。
現(xiàn)在假如有兩個(gè)節(jié)點(diǎn)(啟動(dòng)了client.py文件的機(jī)器) a和b,a中的節(jié)點(diǎn)列表中有b,同樣b中也有,當(dāng)a嘗試著fetch 一個(gè)文件時(shí),如果沒(méi)有在a中查找到的話,則會(huì)去找b,但是b中的節(jié)點(diǎn)列表是a,b會(huì)去找a。。。。。這樣就形成了阻塞。原項(xiàng)目中,是通過(guò)一個(gè)url列表來(lái) 維護(hù)的。但是這個(gè)項(xiàng)目中,a機(jī)器對(duì)于自己的url是localhost,b也是localhost,但是對(duì)于a來(lái)講b就不是localhost。所以我的 項(xiàng)目中,是通過(guò)維護(hù)一個(gè)secret列表來(lái)判斷,下一個(gè)要查找的節(jié)點(diǎn)是不是已經(jīng)被查過(guò)了。但是同時(shí)得先知道下一個(gè)節(jié)點(diǎn)的secret值,但是如果下一節(jié)點(diǎn) 就是上一個(gè)節(jié)點(diǎn)的話,還是會(huì)有阻塞,所以把xml-rpc做成多線程就很必要了。新構(gòu)建一個(gè)類class ThreadRPC(ThreadingMixIn, SimpleXMLRPCServer) 。這樣ThreadRPC就變成了多線程的SimpleXMLRPCServer。
本來(lái)文件的傳輸是使用了xml-rpc。后來(lái)我把它獨(dú)立出來(lái)了。單獨(dú)作為一個(gè)文件傳輸服務(wù),TranServer。這個(gè)文件傳輸,不使用xml- rpc,而是直接用socket。用了SocketServer框架。本來(lái)是想用asynchat的。但是后來(lái)發(fā)現(xiàn),這個(gè)異步框架,有點(diǎn)蛋疼。比如說(shuō)它的 push方法。是會(huì)把數(shù)據(jù)放到叫producer_fifo的fifo數(shù)據(jù)結(jié)構(gòu)中。這個(gè)做會(huì)出現(xiàn)一個(gè)大問(wèn)題。我讀本地的文件速度遠(yuǎn)遠(yuǎn)快于發(fā)送的數(shù)度,當(dāng)體 積大的時(shí)候,更是如此。所以使用push傳輸,會(huì)發(fā)現(xiàn)內(nèi)存占用越來(lái)越大,越來(lái)越大。。。如果不使用push,而是使用send,會(huì)發(fā)現(xiàn)數(shù)據(jù)不同步.鑒于這 些問(wèn)題,所以我沒(méi)有采用異步,而是使用了多線程的SocketServer, ThreadingMixIn
配置文件
[global]
# 監(jiān)聽節(jié)點(diǎn)的端口
listen_port = 1111
# 數(shù)據(jù)傳送的端口
data_port = 1234
# 要共享的目錄
share_dir = /tmp/a
使用方法
啟動(dòng)節(jié)點(diǎn) : python client.py
獲取文件列表: ls
下載文件: fetch xxx
查看文件內(nèi)容: cat xxx [要查看的前n位]
声明:本文内容及配图由入驻作者撰写或者入驻合作网站授权转载。文章观点仅代表作者本人,不代表电子发烧友网立场。文章及其配图仅供工程师学习之用,如有内容侵权或者其他违规问题,请联系本站处理。 举报投诉
- 如何使用Python实现分布式文件共享系统12次下载
- FeiQ局域网文件传输软件应用程序免费下载9次下载
- 查局域网共享电脑的软件应用程序免费下载3次下载
- 局域网共享一键修复2次下载
- 局域网互访共享经典问题81次下载
- XML-RPC技术的多系统松耦合平台中的设计和应用25次下载
- 信道访问与局域网11次下载
- 局域网经典故障解决方法26次下载
- 10日完全精通局域网34次下载
- 基于局域网的网格实现13次下载
- 局域网基于SMB 协议的共享文件和打印信息获取28次下载
- 局域网与城域网0次下载
- 局域网组建与维护课件0次下载
- 局域网组建与维护教程0次下载
- 局域网防攻击软件下载173次下载
- Linux系统共享文件缺失的解决策略1391次阅读
- Linux配置NFS文件共享详解2857次阅读
- 解答无线局域网该如何设置4013次阅读
- 一文了解无线局域网是什么意思39532次阅读
- 浅谈无线局域网的优点3299次阅读
- 广域网和局域网的区别是什么_如何区分这两种网络95120次阅读
- 虚拟局域网vlan的好处及优点分析33043次阅读
- 如何设置虚拟局域网_虚拟局域网的划分方式15504次阅读
- 虚拟局域网的实现方法11968次阅读
- 虚拟局域网有哪几种实现技术11804次阅读
- 虚拟局域网配置实例详解8977次阅读
- 虚拟局域网什么意思_虚拟局域网有什么特点_如何组建虚拟局域网25576次阅读
- 局域网怎么设置共享12248次阅读
- 局域网和外网有什么区别21948次阅读
- 局域网打印机连接设置方法 局域网打印机怎么设置22189次阅读
下載排行
本周
- 1山景DSP芯片AP8248A2數(shù)據(jù)手冊(cè)
- 1.06 MB | 532次下載 | 免費(fèi)
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費(fèi)
- 3TC358743XBG評(píng)估板參考手冊(cè)
- 1.36 MB | 330次下載 | 免費(fèi)
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費(fèi)
- 5元宇宙深度解析—未來(lái)的未來(lái)-風(fēng)口還是泡沫
- 6.40 MB | 227次下載 | 免費(fèi)
- 6迪文DGUS開發(fā)指南
- 31.67 MB | 194次下載 | 免費(fèi)
- 7元宇宙底層硬件系列報(bào)告
- 13.42 MB | 182次下載 | 免費(fèi)
- 8FP5207XR-G1中文應(yīng)用手冊(cè)
- 1.09 MB | 178次下載 | 免費(fèi)
本月
- 1OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 2555集成電路應(yīng)用800例(新編版)
- 0.00 MB | 33566次下載 | 免費(fèi)
- 3接口電路圖大全
- 未知 | 30323次下載 | 免費(fèi)
- 4開關(guān)電源設(shè)計(jì)實(shí)例指南
- 未知 | 21549次下載 | 免費(fèi)
- 5電氣工程師手冊(cè)免費(fèi)下載(新編第二版pdf電子書)
- 0.00 MB | 15349次下載 | 免費(fèi)
- 6數(shù)字電路基礎(chǔ)pdf(下載)
- 未知 | 13750次下載 | 免費(fèi)
- 7電子制作實(shí)例集錦 下載
- 未知 | 8113次下載 | 免費(fèi)
- 8《LED驅(qū)動(dòng)電路設(shè)計(jì)》 溫德爾著
- 0.00 MB | 6656次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935054次下載 | 免費(fèi)
- 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
- 78.1 MB | 537798次下載 | 免費(fèi)
- 3MATLAB 7.1 下載 (含軟件介紹)
- 未知 | 420027次下載 | 免費(fèi)
- 4OrCAD10.5下載OrCAD10.5中文版軟件
- 0.00 MB | 234315次下載 | 免費(fèi)
- 5Altium DXP2002下載入口
- 未知 | 233046次下載 | 免費(fèi)
- 6電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191187次下載 | 免費(fèi)
- 7十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183279次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評(píng)論