資料介紹
軟件簡(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)聽(tīng)某一個(gè)端口上的,有關(guān)xml-rpc服務(wù)器的訪問(wèn)url的監(jiān)聽(tīng)。只要收到信息,就把它寫入到節(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)聽(tīng)節(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次下載
- 查局域網(wǎng)共享電腦的軟件應(yīng)用程序免費(fèi)下載 3次下載
- 局域網(wǎng)共享一鍵修復(fù) 2次下載
- 局域網(wǎng)互訪共享經(jīng)典問(wèn)題 81次下載
- XML-RPC技術(shù)的多系統(tǒng)松耦合平臺(tái)中的設(shè)計(jì)和應(yīng)用 25次下載
- 信道訪問(wèn)與局域網(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次下載
- 多USB 接口的局域網(wǎng)接入技術(shù)的實(shí)現(xiàn)
- 局域網(wǎng)組建與維護(hù)課件 0次下載
- 局域網(wǎng)組建與維護(hù)教程 0次下載
- 局域網(wǎng)防攻擊軟件下載
- Linux系統(tǒng)共享文件缺失的解決策略 2.1k次閱讀
- Linux配置NFS文件共享詳解 3.3k次閱讀
- 解答無(wú)線局域網(wǎng)該如何設(shè)置 4.2k次閱讀
- 一文了解無(wú)線局域網(wǎng)是什么意思 4w次閱讀
- 淺談無(wú)線局域網(wǎng)的優(yōu)點(diǎn) 3.5k次閱讀
- 廣域網(wǎng)和局域網(wǎng)的區(qū)別是什么_如何區(qū)分這兩種網(wǎng)絡(luò) 9.6w次閱讀
- 虛擬局域網(wǎng)vlan的好處及優(yōu)點(diǎn)分析 3.4w次閱讀
- 如何設(shè)置虛擬局域網(wǎng)_虛擬局域網(wǎng)的劃分方式 1.6w次閱讀
- 虛擬局域網(wǎng)的實(shí)現(xiàn)方法 1.2w次閱讀
- 虛擬局域網(wǎng)有哪幾種實(shí)現(xiàn)技術(shù) 1.2w次閱讀
- 虛擬局域網(wǎng)配置實(shí)例詳解 9.2k次閱讀
- 虛擬局域網(wǎng)什么意思_虛擬局域網(wǎng)有什么特點(diǎn)_如何組建虛擬局域網(wǎng) 2.6w次閱讀
- 局域網(wǎng)怎么設(shè)置共享 1.2w次閱讀
- 局域網(wǎng)和外網(wǎng)有什么區(qū)別 2.2w次閱讀
- 局域網(wǎng)打印機(jī)連接設(shè)置方法 局域網(wǎng)打印機(jī)怎么設(shè)置 2.3w次閱讀
下載排行
本周
- 1新一代網(wǎng)絡(luò)可視化(NPB 2.0)
- 3.40 MB | 1次下載 | 免費(fèi)
- 2冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 1次下載 | 10 積分
- 3MDD品牌三極管MMBT3906數(shù)據(jù)手冊(cè)
- 2.33 MB | 次下載 | 免費(fèi)
- 4MDD品牌三極管S9012數(shù)據(jù)手冊(cè)
- 2.62 MB | 次下載 | 免費(fèi)
- 5LAT1218 如何選擇和設(shè)置外部晶體適配 BlueNRG-X
- 0.60 MB | 次下載 | 3 積分
- 6LAT1216 Blue NRG-1/2 系列芯片 Flash 操作與 BLE 事件的互斥處理
- 0.89 MB | 次下載 | 3 積分
- 7收音環(huán)繞擴(kuò)音機(jī) AVR-1507手冊(cè)
- 2.50 MB | 次下載 | 免費(fèi)
- 8MS1000TA 超聲波測(cè)量模擬前端芯片技術(shù)手冊(cè)
- 0.60 MB | 次下載 | 免費(fèi)
本月
- 1愛(ài)華AIWA HS-J202維修手冊(cè)
- 3.34 MB | 37次下載 | 免費(fèi)
- 2PC5502負(fù)載均流控制電路數(shù)據(jù)手冊(cè)
- 1.63 MB | 23次下載 | 免費(fèi)
- 3NB-IoT芯片廠商的資料說(shuō)明
- 0.31 MB | 22次下載 | 1 積分
- 4UWB653Pro USB口測(cè)距通信定位模塊規(guī)格書
- 838.47 KB | 5次下載 | 免費(fèi)
- 5蘇泊爾DCL6907(即CHK-S007)單芯片電磁爐原理圖資料
- 0.04 MB | 4次下載 | 1 積分
- 6蘇泊爾DCL6909(即CHK-S009)單芯片電磁爐原理圖資料
- 0.08 MB | 2次下載 | 1 積分
- 7100W準(zhǔn)諧振反激式恒流電源電路圖資料
- 0.09 MB | 2次下載 | 1 積分
- 8FS8025B USB的PD和OC快充協(xié)議電壓誘騙控制器IC技術(shù)手冊(cè)
- 1.81 MB | 1次下載 | 免費(fèi)
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計(jì)
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費(fèi)下載
- 340992 | 191439次下載 | 10 積分
- 5十天學(xué)會(huì)AVR單片機(jī)與C語(yǔ)言視頻教程 下載
- 158M | 183353次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81602次下載 | 10 積分
- 7Keil工具M(jìn)DK-Arm免費(fèi)下載
- 0.02 MB | 73822次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





創(chuàng)作
發(fā)文章
發(fā)帖
提問(wèn)
發(fā)資料
發(fā)視頻
上傳資料賺積分
評(píng)論