嵌入式移動數(shù)據(jù)庫中的移動Agent問題探討
4 基于移動Agent的嵌入式移動數(shù)據(jù)庫的研究側(cè)重點
1) 移動Agent的協(xié)同。移動Agent具有自主性,同時也具有協(xié)作性,能夠相互合作,從而高效透明的使用網(wǎng)絡上的資源[3]。通常各種數(shù)據(jù)資源存儲在各個不同的網(wǎng)絡節(jié)點上,隨著數(shù)據(jù)庫技術(shù)的發(fā)展,很多應用都涉及到訪問不同位置的數(shù)據(jù)庫,對此,用戶可以創(chuàng)建多個Agent,讓其分散到網(wǎng)絡的多個節(jié)點上去執(zhí)行,當多個移動Agent共同完成一個任務時,Agent之間需要進行通信,移動Agent系統(tǒng)可采用的通信方式有很多,比如 RPC,RMI等,在具體的代理系統(tǒng)中,通信的實現(xiàn)方式則有很大的差別。如:Cornell大學的Tocama通過一個攜帶數(shù)據(jù)的briefcase來交換數(shù)據(jù);General Magic公司的Telescript中Agent只能在會話點中用本地方法調(diào)用的方式相互通信; Dartmouth學院的D’Agent既支持底層的基于字節(jié)流的消息傳遞方式,也支持基于Agent層次的高層通信方式。
2) 移動Agent的重定位。移動Agent在完成客戶Agent所提出的任務時,由于所需的資源可能分布在網(wǎng)絡不同的節(jié)點上, Agent需要在網(wǎng)絡中移動。在移動數(shù)據(jù)庫系統(tǒng)中,移動客戶端的位置通常不斷發(fā)生變化,這時,Agent也需要根據(jù)移動客戶端的位置重新在網(wǎng)絡中進行定位,從而縮短與移動客戶端的距離,達到減少通信時間以及網(wǎng)絡通信開銷的目的。對于移動Agent的重定位方法可以采取如下方式:(1)通過使用位置服務器。當移動Agent創(chuàng)建時,在相應的位置服務器中注冊當前位置,當移動Agent發(fā)生位置變化時,要在位置服務器中更新自己的位置信息,要定位所需的移動Agent通過向位置服務器查詢即可。(2)通過跟蹤移動Agent的移動路徑。移動Agent遷移時,記錄下移動Agent的遷移路徑,從而可以根據(jù)路徑來定位所需的移動Agent。(3)通過發(fā)送廣播消息,采取與局域網(wǎng)中ARP協(xié)議類似的方法,向系統(tǒng)內(nèi)所有節(jié)點發(fā)送廣播消息,由符合的條件的移動 Agent發(fā)回響應消息。
3) 并發(fā)操作的控制。嵌入式移動數(shù)據(jù)庫在實際應用中必須解決好數(shù)據(jù)的一致性[4],在移動數(shù)據(jù)庫系統(tǒng)中,有時存在多個Agent并發(fā)訪問共享信息的情況,為了保證數(shù)據(jù)的一致性,需要對并發(fā)操作進行正確的控制,目的是為了避免出現(xiàn)使數(shù)據(jù)處于不一致狀態(tài)的并發(fā)事物調(diào)度。在基于移動Agent的系統(tǒng)中,既要維護本地數(shù)據(jù)庫系統(tǒng)的一致性,也要維護網(wǎng)絡節(jié)點上數(shù)據(jù)庫系統(tǒng)的一致性。并發(fā)控制可以借助DBMS本身的功能來完成,因為目前一般的數(shù)據(jù)庫管理系統(tǒng)都有較好的并發(fā)控制功能,同時也可借助一些開發(fā)工具來實現(xiàn)并發(fā)控制。相對于傳統(tǒng)的數(shù)據(jù)庫系統(tǒng),Agent并發(fā)控制相對較復雜,可能存在網(wǎng)絡節(jié)點上的數(shù)據(jù)庫不完全接受Agent的控制、本地數(shù)據(jù)庫與網(wǎng)絡節(jié)點上的數(shù)據(jù)庫之間存在相互約束關(guān)系等一些影響因素。
4)故障的恢復。在基于移動Agent的移動數(shù)據(jù)庫系統(tǒng)中,故障恢復較傳統(tǒng)的數(shù)據(jù)庫系統(tǒng)也相對復雜一些,需要恢復網(wǎng)絡節(jié)點上的各個數(shù)據(jù)庫中的數(shù)據(jù)、恢復每個Agent的本地數(shù)據(jù)以及運行時的環(huán)境。對于網(wǎng)絡節(jié)點上的各個數(shù)據(jù)庫以及每個Agent的本地數(shù)據(jù)的故障恢復可以借助DBMS本身的功能來完成。對于Agent運行時的環(huán)境的恢復可以通過專門為對應的Agent新建一個數(shù)據(jù)庫來維護運行時的環(huán)境,當Agent需要對數(shù)據(jù)進行更新操作時,先更新在為其新建的那個數(shù)據(jù)庫中,當整個事物完成時再提交數(shù)據(jù)給本地數(shù)據(jù)庫。
5 結(jié)束語
針對移動數(shù)據(jù)庫具有的移動性、斷接性、網(wǎng)絡條件多樣性、網(wǎng)絡通信的非對稱性、移動計算機的弱電源能力等特性,將移動Agent技術(shù)引入到移動數(shù)據(jù)庫中,移動Agent計算模式能有效的減少網(wǎng)絡通信流量、減少訪問服務器的延遲、支持斷接操作、支持異步計算等,使得移動Agent的優(yōu)點得到了很大的發(fā)揮,有助于實現(xiàn)移動數(shù)據(jù)庫的各種操作。由于移動Agent技術(shù)本身還處于發(fā)展過程中,應用移動Agent來完善移動數(shù)據(jù)庫技術(shù)還有待于更加深入的研究和探索。
本文作者創(chuàng)新點:
鑒于在分布式數(shù)據(jù)庫中使用的多層架構(gòu)技術(shù)在訪問量大的情況下能較好的適應數(shù)據(jù)庫的各種操作,筆者在移動數(shù)據(jù)庫中借鑒其相關(guān)技術(shù)同時利用了移動Agent的特點,并對由此產(chǎn)生的部分問題探討了其初步的解決方式。
參考文獻:
[1] 朱淼良,邱瑜.移動代理系統(tǒng)綜述[J],計算機研究與發(fā)展,2001,38(1):16-25.
[2]王彤,王良. 移動計算中基于Mobile Agent的數(shù)據(jù)庫訪問技術(shù),小型微型計算機系統(tǒng),2002,23(10):1165-1168.
[3] 劉振鵬等.基于協(xié)同式移動Agent分布式數(shù)據(jù)庫系統(tǒng)研究[J], 計算機工程與設(shè)計, 2004,24(11):10-12.
[4] 牛立新,關(guān)永,劉旭敏. 嵌入式移動數(shù)據(jù)庫研究, 微計算機信息, 2006,第22卷第1-2期,85-87頁轉(zhuǎn)251頁
linux操作系統(tǒng)文章專題:linux操作系統(tǒng)詳解(linux不再難懂)
評論