資料介紹
軟件簡介
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)的集合。原文的例子,功能太少,只能下載。后來我加了一個(gè)ls 命令,可以查看包括自己的和所有節(jié)點(diǎn)的文件。原項(xiàng)目中的節(jié)點(diǎn)列表,必須是手動(dòng)給出的,相當(dāng)麻煩,是通過一個(gè)叫urlfile的文件來維護(hù)的。在我的這個(gè)項(xiàng) 目中,維護(hù) 節(jié)點(diǎn)的信息是通過程序自己學(xué)習(xí)到的。每當(dāng)一個(gè)節(jié)點(diǎn)啟動(dòng)的時(shí)候,該節(jié)點(diǎn)就會(huì)把自己的xml-rpc服務(wù)器的訪問url,通過udp廣播的方式,廣播給某一個(gè) 端口。同時(shí)每一個(gè)節(jié)點(diǎn),只要它啟動(dòng)后,會(huì)監(jiān)聽某一個(gè)端口上的,有關(guān)xml-rpc服務(wù)器的訪問url的監(jiān)聽。只要收到信息,就把它寫入到節(jié)點(diǎn)列表中。通過 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í),如果沒有在a中查找到的話,則會(huì)去找b,但是b中的節(jié)點(diǎn)列表是a,b會(huì)去找a。。。。。這樣就形成了阻塞。原項(xiàng)目中,是通過一個(gè)url列表來 維護(hù)的。但是這個(gè)項(xiàng)目中,a機(jī)器對于自己的url是localhost,b也是localhost,但是對于a來講b就不是localhost。所以我的 項(xiàng)目中,是通過維護(hù)一個(gè)secret列表來判斷,下一個(gè)要查找的節(jié)點(diǎn)是不是已經(jīng)被查過了。但是同時(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。
本來文件的傳輸是使用了xml-rpc。后來我把它獨(dú)立出來了。單獨(dú)作為一個(gè)文件傳輸服務(wù),TranServer。這個(gè)文件傳輸,不使用xml- rpc,而是直接用socket。用了SocketServer框架。本來是想用asynchat的。但是后來發(fā)現(xiàn),這個(gè)異步框架,有點(diǎn)蛋疼。比如說它的 push方法。是會(huì)把數(shù)據(jù)放到叫producer_fifo的fifo數(shù)據(jù)結(jié)構(gòu)中。這個(gè)做會(huì)出現(xiàn)一個(gè)大問題。我讀本地的文件速度遠(yuǎn)遠(yuǎn)快于發(fā)送的數(shù)度,當(dāng)體 積大的時(shí)候,更是如此。所以使用push傳輸,會(huì)發(fā)現(xiàn)內(nèi)存占用越來越大,越來越大。。。如果不使用push,而是使用send,會(huì)發(fā)現(xiàn)數(shù)據(jù)不同步.鑒于這 些問題,所以我沒有采用異步,而是使用了多線程的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實(shí)現(xiàn)分布式文件共享系統(tǒng) 12次下載
- FeiQ局域網(wǎng)文件傳輸軟件應(yīng)用程序免費(fèi)下載 9次下載
- 查局域網(wǎng)共享電腦的軟件應(yīng)用程序免費(fèi)下載 3次下載
- 局域網(wǎng)共享一鍵修復(fù) 2次下載
- 局域網(wǎng)互訪共享經(jīng)典問題 81次下載
- XML-RPC技術(shù)的多系統(tǒng)松耦合平臺(tái)中的設(shè)計(jì)和應(yīng)用 25次下載
- 信道訪問與局域網(wǎng)
- 局域網(wǎng)經(jīng)典故障解決方法
- 10日完全精通局域網(wǎng)
- 基于局域網(wǎng)的網(wǎng)格實(shí)現(xiàn)
- 局域網(wǎng)基于SMB 協(xié)議的共享文件和打印信息獲取
- 局域網(wǎng)與城域網(wǎng) 0次下載
- 局域網(wǎng)組建與維護(hù)課件 0次下載
- 局域網(wǎng)組建與維護(hù)教程 0次下載
- 局域網(wǎng)防攻擊軟件下載
- Linux系統(tǒng)共享文件缺失的解決策略 636次閱讀
- Linux配置NFS文件共享詳解 2261次閱讀
- 解答無線局域網(wǎng)該如何設(shè)置 3619次閱讀
- 一文了解無線局域網(wǎng)是什么意思 3.1w次閱讀
- 淺談無線局域網(wǎng)的優(yōu)點(diǎn) 2923次閱讀
- 廣域網(wǎng)和局域網(wǎng)的區(qū)別是什么_如何區(qū)分這兩種網(wǎng)絡(luò) 9.3w次閱讀
- 虛擬局域網(wǎng)vlan的好處及優(yōu)點(diǎn)分析 3.1w次閱讀
- 如何設(shè)置虛擬局域網(wǎng)_虛擬局域網(wǎng)的劃分方式 1.4w次閱讀
- 虛擬局域網(wǎng)的實(shí)現(xiàn)方法 1.1w次閱讀
- 虛擬局域網(wǎng)有哪幾種實(shí)現(xiàn)技術(shù) 1.1w次閱讀
- 虛擬局域網(wǎng)配置實(shí)例詳解 8593次閱讀
- 虛擬局域網(wǎng)什么意思_虛擬局域網(wǎng)有什么特點(diǎn)_如何組建虛擬局域網(wǎng) 2.4w次閱讀
- 局域網(wǎng)怎么設(shè)置共享 1.1w次閱讀
- 局域網(wǎng)和外網(wǎng)有什么區(qū)別 2.1w次閱讀
- 局域網(wǎng)打印機(jī)連接設(shè)置方法 局域網(wǎng)打印機(jī)怎么設(shè)置 2.1w次閱讀
下載排行
本周
- 1山景DSP芯片AP8248A2數(shù)據(jù)手冊
- 1.06 MB | 532次下載 | 免費(fèi)
- 2RK3399完整板原理圖(支持平板,盒子VR)
- 3.28 MB | 339次下載 | 免費(fèi)
- 3TC358743XBG評估板參考手冊
- 1.36 MB | 330次下載 | 免費(fèi)
- 4DFM軟件使用教程
- 0.84 MB | 295次下載 | 免費(fèi)
- 5元宇宙深度解析—未來的未來-風(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)用手冊
- 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電氣工程師手冊免費(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語言視頻教程 下載
- 158M | 183279次下載 | 免費(fèi)
- 8proe5.0野火版下載(中文版免費(fèi)下載)
- 未知 | 138040次下載 | 免費(fèi)
評論
查看更多