資料介紹
軟件簡介
xml-rpc 實現(xiàn)的文件共享
這個項目取材與http://www.the5fire.com/python-project8-xml-rpc.html 。是python基礎(chǔ)教程中的十個例子中的第八個。主要的實現(xiàn)原理如下:
每一個客戶端都是一個節(jié)點。每一個節(jié)點,都啟動一個 xml-rpc服務(wù)器。在 xml-rpc服務(wù)器中,維護著一個所有節(jié)點的集合。原文的例子,功能太少,只能下載。后來我加了一個ls 命令,可以查看包括自己的和所有節(jié)點的文件。原項目中的節(jié)點列表,必須是手動給出的,相當(dāng)麻煩,是通過一個叫urlfile的文件來維護的。在我的這個項 目中,維護 節(jié)點的信息是通過程序自己學(xué)習(xí)到的。每當(dāng)一個節(jié)點啟動的時候,該節(jié)點就會把自己的xml-rpc服務(wù)器的訪問url,通過udp廣播的方式,廣播給某一個 端口。同時每一個節(jié)點,只要它啟動后,會監(jiān)聽某一個端口上的,有關(guān)xml-rpc服務(wù)器的訪問url的監(jiān)聽。只要收到信息,就把它寫入到節(jié)點列表中。通過 fetch下載文件時,如果發(fā)現(xiàn)了異常,則從節(jié)點列表中刪除它。
現(xiàn)在假如有兩個節(jié)點(啟動了client.py文件的機器) a和b,a中的節(jié)點列表中有b,同樣b中也有,當(dāng)a嘗試著fetch 一個文件時,如果沒有在a中查找到的話,則會去找b,但是b中的節(jié)點列表是a,b會去找a。。。。。這樣就形成了阻塞。原項目中,是通過一個url列表來 維護的。但是這個項目中,a機器對于自己的url是localhost,b也是localhost,但是對于a來講b就不是localhost。所以我的 項目中,是通過維護一個secret列表來判斷,下一個要查找的節(jié)點是不是已經(jīng)被查過了。但是同時得先知道下一個節(jié)點的secret值,但是如果下一節(jié)點 就是上一個節(jié)點的話,還是會有阻塞,所以把xml-rpc做成多線程就很必要了。新構(gòu)建一個類class ThreadRPC(ThreadingMixIn, SimpleXMLRPCServer) 。這樣ThreadRPC就變成了多線程的SimpleXMLRPCServer。
本來文件的傳輸是使用了xml-rpc。后來我把它獨立出來了。單獨作為一個文件傳輸服務(wù),TranServer。這個文件傳輸,不使用xml- rpc,而是直接用socket。用了SocketServer框架。本來是想用asynchat的。但是后來發(fā)現(xiàn),這個異步框架,有點蛋疼。比如說它的 push方法。是會把數(shù)據(jù)放到叫producer_fifo的fifo數(shù)據(jù)結(jié)構(gòu)中。這個做會出現(xiàn)一個大問題。我讀本地的文件速度遠遠快于發(fā)送的數(shù)度,當(dāng)體 積大的時候,更是如此。所以使用push傳輸,會發(fā)現(xiàn)內(nèi)存占用越來越大,越來越大。。。如果不使用push,而是使用send,會發(fā)現(xiàn)數(shù)據(jù)不同步.鑒于這 些問題,所以我沒有采用異步,而是使用了多線程的SocketServer, ThreadingMixIn
配置文件
[global]
# 監(jiān)聽節(jié)點的端口
listen_port = 1111
# 數(shù)據(jù)傳送的端口
data_port = 1234
# 要共享的目錄
share_dir = /tmp/a
使用方法
啟動節(jié)點 : python client.py
獲取文件列表: ls
下載文件: fetch xxx
查看文件內(nèi)容: cat xxx [要查看的前n位]
- 如何使用Python實現(xiàn)分布式文件共享系統(tǒng) 12次下載
- 查局域網(wǎng)共享電腦的軟件應(yīng)用程序免費下載 3次下載
- 局域網(wǎng)共享一鍵修復(fù) 2次下載
- 局域網(wǎng)互訪共享經(jīng)典問題 81次下載
- XML-RPC技術(shù)的多系統(tǒng)松耦合平臺中的設(shè)計和應(yīng)用 25次下載
- 信道訪問與局域網(wǎng)
- 局域網(wǎng)經(jīng)典故障解決方法
- 10日完全精通局域網(wǎng)
- 基于局域網(wǎng)的網(wǎng)格實現(xiàn)
- 局域網(wǎng)基于SMB 協(xié)議的共享文件和打印信息獲取
- 局域網(wǎng)與城域網(wǎng) 0次下載
- 多USB 接口的局域網(wǎng)接入技術(shù)的實現(xiàn)
- 局域網(wǎng)組建與維護課件 0次下載
- 局域網(wǎng)組建與維護教程 0次下載
- 局域網(wǎng)防攻擊軟件下載
- Linux系統(tǒng)共享文件缺失的解決策略 2.1k次閱讀
- Linux配置NFS文件共享詳解 3.3k次閱讀
- 解答無線局域網(wǎng)該如何設(shè)置 4.2k次閱讀
- 一文了解無線局域網(wǎng)是什么意思 4w次閱讀
- 淺談無線局域網(wǎng)的優(yōu)點 3.5k次閱讀
- 廣域網(wǎng)和局域網(wǎng)的區(qū)別是什么_如何區(qū)分這兩種網(wǎng)絡(luò) 9.6w次閱讀
- 虛擬局域網(wǎng)vlan的好處及優(yōu)點分析 3.4w次閱讀
- 如何設(shè)置虛擬局域網(wǎng)_虛擬局域網(wǎng)的劃分方式 1.6w次閱讀
- 虛擬局域網(wǎng)的實現(xiàn)方法 1.2w次閱讀
- 虛擬局域網(wǎng)有哪幾種實現(xiàn)技術(shù) 1.2w次閱讀
- 虛擬局域網(wǎng)配置實例詳解 9.2k次閱讀
- 虛擬局域網(wǎng)什么意思_虛擬局域網(wǎng)有什么特點_如何組建虛擬局域網(wǎng) 2.6w次閱讀
- 局域網(wǎng)怎么設(shè)置共享 1.2w次閱讀
- 局域網(wǎng)和外網(wǎng)有什么區(qū)別 2.2w次閱讀
- 局域網(wǎng)打印機連接設(shè)置方法 局域網(wǎng)打印機怎么設(shè)置 2.3w次閱讀
下載排行
本周
- 1新一代網(wǎng)絡(luò)可視化(NPB 2.0)
- 3.40 MB | 1次下載 | 免費
- 2冷柜-電氣控制系統(tǒng)講解
- 13.68 MB | 1次下載 | 10 積分
- 3MDD品牌三極管MMBT3906數(shù)據(jù)手冊
- 2.33 MB | 次下載 | 免費
- 4MDD品牌三極管S9012數(shù)據(jù)手冊
- 2.62 MB | 次下載 | 免費
- 5LAT1218 如何選擇和設(shè)置外部晶體適配 BlueNRG-X
- 0.60 MB | 次下載 | 3 積分
- 6LAT1216 Blue NRG-1/2 系列芯片 Flash 操作與 BLE 事件的互斥處理
- 0.89 MB | 次下載 | 3 積分
- 7收音環(huán)繞擴音機 AVR-1507手冊
- 2.50 MB | 次下載 | 免費
- 8MS1000TA 超聲波測量模擬前端芯片技術(shù)手冊
- 0.60 MB | 次下載 | 免費
本月
- 1愛華AIWA HS-J202維修手冊
- 3.34 MB | 37次下載 | 免費
- 2PC5502負載均流控制電路數(shù)據(jù)手冊
- 1.63 MB | 23次下載 | 免費
- 3NB-IoT芯片廠商的資料說明
- 0.31 MB | 22次下載 | 1 積分
- 4UWB653Pro USB口測距通信定位模塊規(guī)格書
- 838.47 KB | 5次下載 | 免費
- 5蘇泊爾DCL6907(即CHK-S007)單芯片電磁爐原理圖資料
- 0.04 MB | 4次下載 | 1 積分
- 6蘇泊爾DCL6909(即CHK-S009)單芯片電磁爐原理圖資料
- 0.08 MB | 2次下載 | 1 積分
- 7100W準諧振反激式恒流電源電路圖資料
- 0.09 MB | 2次下載 | 1 積分
- 8FS8025B USB的PD和OC快充協(xié)議電壓誘騙控制器IC技術(shù)手冊
- 1.81 MB | 1次下載 | 免費
總榜
- 1matlab軟件下載入口
- 未知 | 935137次下載 | 10 積分
- 2開源硬件-PMP21529.1-4 開關(guān)降壓/升壓雙向直流/直流轉(zhuǎn)換器 PCB layout 設(shè)計
- 1.48MB | 420064次下載 | 10 積分
- 3Altium DXP2002下載入口
- 未知 | 233089次下載 | 10 積分
- 4電路仿真軟件multisim 10.0免費下載
- 340992 | 191439次下載 | 10 積分
- 5十天學(xué)會AVR單片機與C語言視頻教程 下載
- 158M | 183353次下載 | 10 積分
- 6labview8.5下載
- 未知 | 81602次下載 | 10 積分
- 7Keil工具MDK-Arm免費下載
- 0.02 MB | 73822次下載 | 10 積分
- 8LabVIEW 8.6下載
- 未知 | 65991次下載 | 10 積分
電子發(fā)燒友App





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