日本黄色一级经典视频|伊人久久精品视频|亚洲黄色色周成人视频九九九|av免费网址黄色小短片|黄色Av无码亚洲成年人|亚洲1区2区3区无码|真人黄片免费观看|无码一级小说欧美日免费三级|日韩中文字幕91在线看|精品久久久无码中文字幕边打电话

當前位置:首頁 > 嵌入式 > 嵌入式硬件
[導讀]提出一種新的嵌入式內(nèi)存數(shù)據(jù)庫的設計方法,該方法結(jié)合當前流行的java語言和面向?qū)ο蟮乃枷?充分利用java語言本身的多線程機制,研究出基于多線程機制的嵌入式內(nèi)存數(shù)據(jù)庫的事務模型,檢查點方法和恢復策略,同時對數(shù)據(jù)庫的存儲管理和索引機制進行了探討。

0引言

隨著硬件的發(fā)展,內(nèi)存的容量在不斷擴大,人們長期思考的將全部或大部分數(shù)據(jù)存放在 內(nèi)存中運行成為可能。同時,嵌入式設備在日常生活中得到廣泛應用,如何對其內(nèi)部日益繁 多的數(shù)據(jù)進行管理顯得很關(guān)鍵。當前嵌入式內(nèi)存數(shù)據(jù)庫產(chǎn)品很多,大多數(shù)產(chǎn)品由于各方面的 限制,在性能和市場前景方面表現(xiàn)欠佳。在嵌入式內(nèi)存數(shù)據(jù)庫研究領域,新的存儲與索引方 法被不斷提出,同時面向?qū)ο蟮某绦蛟O計語言java作為當前主流開發(fā)語言,在多線程和死鎖 處理方面有其獨特之處,為提出新的嵌入式內(nèi)存數(shù)據(jù)庫的設計方法,及基于事務模型的恢復 方法提供了可能。

1嵌入式內(nèi)存數(shù)據(jù)庫概述

嵌入式內(nèi)存數(shù)據(jù)庫的設計一般采取兩種思路:一種是對傳統(tǒng)的大型數(shù)據(jù)庫進行裁剪和改 進,很多處理問題的方法仍采用傳統(tǒng)數(shù)據(jù)庫的方法,某些方法在嵌入式內(nèi)存數(shù)據(jù)庫不適用則 做些稍微改進,這種思路沒有逃離傳統(tǒng)數(shù)據(jù)庫設計思想的束縛。另一種則是根據(jù)嵌入式內(nèi)存 數(shù)據(jù)庫自身的特點,提出新的體系結(jié)構(gòu),存儲結(jié)構(gòu)和恢復機制,以滿足嵌入式內(nèi)存數(shù)據(jù)庫的 要求。目前,第二種方法被普遍采用和推崇,本文新的設計方法就采用后者。


1.2嵌入式內(nèi)存數(shù)據(jù)庫的體系結(jié)構(gòu)

在新的體系結(jié)構(gòu)中,我們采用關(guān)系數(shù)據(jù)模型,最上層提供外部查詢接口,支持多種常用 語言如C,java等語言連接數(shù)據(jù)庫。第二層是對SQL語句進行解析的查詢命令分解與優(yōu)化層, 這一層下面是兩個重要的模塊:數(shù)據(jù)組織與管理和事務管理器。其中,數(shù)據(jù)組織與管理模塊 完成常用的索引和數(shù)據(jù)組織工作,事務管理器具有創(chuàng)建事務,調(diào)度事務,回收事務的功能。 內(nèi)存工作區(qū)是該體系結(jié)構(gòu)最重要的模塊,全部數(shù)據(jù)操作及日志處理在這里進行,它在事務處 理時為每一個事務分配一個內(nèi)存工作區(qū),其中存放數(shù)據(jù)和日志。日志管理器管理內(nèi)存工作區(qū) 中的日志,而恢復管理器則在系統(tǒng)出現(xiàn)故障時起作用。該數(shù)據(jù)庫大部分操作在內(nèi)存工作區(qū)中 運行,只有當發(fā)生檢查點操作和數(shù)據(jù)庫備份,及系統(tǒng)恢復時才與外面的磁盤打交道,因此該 數(shù)據(jù)庫是典型的嵌入式內(nèi)存數(shù)據(jù)庫。上述體系結(jié)構(gòu)圖如圖1所示:


2.數(shù)據(jù)的存儲與索引

嵌入式內(nèi)存數(shù)據(jù)庫通常在內(nèi)存受限的環(huán)境中進行,CPU能直接操縱內(nèi)存中的數(shù)據(jù),且數(shù) 據(jù)經(jīng)常由于各種故障而丟失。因此合理的有效利用內(nèi)存資源,減少內(nèi)存開銷和CPU指令數(shù), 使內(nèi)存空間得到高效利用很關(guān)鍵,為此我們引用了一種新的存儲與索引方法——T樹。

T樹是將AVL樹和B樹結(jié)合在一起而得出的一種新的數(shù)據(jù)結(jié)構(gòu),T樹也是一種二叉樹,只不 過每個結(jié)點(稱為T結(jié)點)都包含多個元素。每個T結(jié)點都包含一系列從小到大排序后的元素和 三個指針,指針分別指向父結(jié)點和左右結(jié)點。某一T結(jié)點A的左結(jié)點中必會包含比A結(jié)點中最 小元素小的最大元素,而A結(jié)點的右結(jié)點中必會包含比A結(jié)點中最大元素大的最小元素。因為 是二叉樹,所以T樹具有AVL樹固有的二分查找特性,又因為每個結(jié)點包含多個元素,其又包 含了B樹良好的更新和存儲特性的優(yōu)點。對T樹來說,因插入和刪除數(shù)據(jù)所造成的數(shù)據(jù)移動通 常可以局限在一個結(jié)點內(nèi)進行,和AVL樹一樣,T樹也是通過旋轉(zhuǎn)來使樹達到平衡的, 但其所 需要的旋轉(zhuǎn)操作的次數(shù)遠少于AVL樹[ 2 ]。T樹結(jié)點結(jié)構(gòu)如圖2所示:


3基于事務處理的恢復模塊設計

本嵌入式內(nèi)存數(shù)據(jù)庫,我們采用了基于多線程的事務模型,利用java語言作為開發(fā)語言, Eclipse3.2為開發(fā)工具,充分采用java語言的多線程機制和面向?qū)ο蟮乃枷雭黹_發(fā)數(shù)據(jù)庫。

在該事務模型中,我們將事務作為一個線程來看待,理由如下:(1)java語言有自己獨特 的多線程機制,具有開始狀態(tài),各種活動狀態(tài),結(jié)束狀態(tài),把線程作為一個事務整體運行, 能夠滿足事務需求的各種操作,及自身的ACID屬性。(2)java語言有多線程處理時的同步操 作,事務處理時可以利用這種思想處理多事務之間的并發(fā)控制操作[ 3 ] 。我們利用事務管理 器創(chuàng)建事務,并在影子內(nèi)存工作區(qū)為每一個事務分配相應的影子內(nèi)存工作區(qū),其中包括該事 務應處理的數(shù)據(jù)和日志,可以說該模型是影子內(nèi)存技術(shù)和日志處理技術(shù)的完美結(jié)合。其中, 新的事務模型和處理機制如下圖3所示。


3.1 日志操作

對每一個事務Ti分配一個內(nèi)存工作區(qū)WAi,兼做影子內(nèi)存和日志兩種功能。在事務進入 提交狀態(tài)之前,將修改記錄放入影子內(nèi)存中,當Ti進入提交狀態(tài)時,由提交處理根據(jù)WAi中 的記錄對MDB作相應修改。我們稱這種修改為“日志驅(qū)動修改”。當某一事務Tj由于某種原 因夭折時,只需釋放其相應的影子內(nèi)存工作區(qū)WAj即可, 而無需對數(shù)據(jù)庫進行UNDO操作。因 此在本文中我們采用Redo日志。這樣,不僅可以大大節(jié)省內(nèi)存空間,同時也簡化了Abort(夭 折)處理。同時,為了便于對影子內(nèi)存工作區(qū)的管理,給每一個影子內(nèi)存工作區(qū)WAi設置一時 間戳TWAi,用來表示對應事務提交過程結(jié)束的時間。在處理日志提交時,我們充分利用事務 預提交和組提交的優(yōu)點來設計。具體過程如下,每一個已提交事務的WAi進行預提交,按時 間先后順序組成鏈表LiST(WAi),其結(jié)構(gòu)如下:

事務進入提交階段,提交處理(COMMIteR)對MDB作“日志驅(qū)動修改”。當上述事務都完成時,進行一次組提交,將上述事務的處理結(jié)果和日志寫入磁盤,這樣可以減少磁盤I/O操作的次數(shù)。

3.1.1事務提交算法

事務提交具體算法如下:設WAi為活動事務Ti的影子內(nèi)存工作區(qū),則事務Ti在時刻t的提 交處理算法為COMMITER(WAi,t)[ 4 ]。
輸入:WAi--事務Ti的影子工作區(qū);t--某一個時間點。
輸出:0--執(zhí)行成功;1--執(zhí)行失敗。
步驟: ①依據(jù)WAi中的記錄,對內(nèi)存中所有要被事務Ti修改的數(shù)據(jù)塊執(zhí)行上鎖操作;② 對已上鎖的數(shù)據(jù)塊, 根據(jù)WAi中的記錄執(zhí)行相應的更新操作;③在WAi中寫入一個提交記錄; ④用當前時間t為WAi設置時間戳TWAi;⑤將WAi加入到影子工作區(qū)隊列的尾部;⑥將事務表 中該事務的狀態(tài)標志位從運行狀態(tài)改為提交狀態(tài);⑦對在步驟①中上鎖了的數(shù)據(jù)塊解鎖。

3.1.2日志提交算法

在事務處理中,用于恢復的日志對WA的處理算法為LOGGER(WAq),日志提交算法如下:
輸入:WAq--影子工作區(qū)隊列。
輸出:0--執(zhí)行成功;1--執(zhí)行失敗。
步驟:①檢查WAq 是否為空,若不空,則從隊列頭取出第一個影子工作區(qū)WAx;若為空, 則掛起;②將WAx中的記錄寫入外存的日志文件LOG中;③釋放WAx;④將事務表中相應于WAx 的事務的狀態(tài)標志位從提交改為撤銷;⑤轉(zhuǎn)步驟①循環(huán)執(zhí)行。

3.2檢查點操作

檢查點操作包括靜止檢查點和非靜止檢查點。靜止檢查點要求操作過程中,數(shù)據(jù)庫處于 靜止狀態(tài),檢查點結(jié)束后,開始新的事務。在嵌入式內(nèi)存數(shù)據(jù)庫對實時性要求很高靜止檢查 點很明顯不能滿足要求,因此我們采用非靜止檢查點。

在CHECKPOINT操作期間,由于采用的是Redo日志,提交事務所做的修改拷貝到磁盤的時 間可能比事務提交的時間晚得多,且采用預提交和組提交技術(shù),我們要考慮檢查點發(fā)生時的 活動事務,及在檢查點進行前將影子內(nèi)存工作區(qū)中,已提交的事務和日志刷新到磁盤中作為 備份。執(zhí)行檢查點的步驟如下[5 ]:


3.3重裝與恢復

恢復涉及到兩個步驟,首先是重裝,將數(shù)據(jù)庫備份裝入MMDB 中;然后是恢復,根據(jù)日 志和檢驗點執(zhí)行相應操作使數(shù)據(jù)庫恢復到系統(tǒng)崩潰之前最近的一致性狀態(tài)。檢查點可以幫我 們縮小日志的范圍,減少日志占用的空間資源,根據(jù)最后一個檢查點記錄是START還是END, 有以下兩種情況。


4結(jié)束語

在嵌入式內(nèi)存數(shù)據(jù)庫領域,隨著程序語言的發(fā)展,數(shù)據(jù)庫理論的成熟,新的設計思想和 技術(shù)在不斷涌現(xiàn),各種產(chǎn)品應運而生。本文就是結(jié)合當今流行的java 語言和面向?qū)ο蟮乃?想,結(jié)合嵌入式內(nèi)存數(shù)據(jù)庫本身的特征,充分利用java 的多線程機制與事務處理的結(jié)合來 提出新的事務模型,同時融合了影子技術(shù)和日志技術(shù),提出了新的恢復處理方法。但是本文 在很多方面還有不足之處,尤其是重裝與恢復算法方法,還有很多具體的工作要做。

本站聲明: 本文章由作者或相關(guān)機構(gòu)授權(quán)發(fā)布,目的在于傳遞更多信息,并不代表本站贊同其觀點,本站亦不保證或承諾內(nèi)容真實性等。需要轉(zhuǎn)載請聯(lián)系該專欄作者,如若文章內(nèi)容侵犯您的權(quán)益,請及時聯(lián)系本站刪除。
換一批
延伸閱讀

LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: 驅(qū)動電源

在工業(yè)自動化蓬勃發(fā)展的當下,工業(yè)電機作為核心動力設備,其驅(qū)動電源的性能直接關(guān)系到整個系統(tǒng)的穩(wěn)定性和可靠性。其中,反電動勢抑制與過流保護是驅(qū)動電源設計中至關(guān)重要的兩個環(huán)節(jié),集成化方案的設計成為提升電機驅(qū)動性能的關(guān)鍵。

關(guān)鍵字: 工業(yè)電機 驅(qū)動電源

LED 驅(qū)動電源作為 LED 照明系統(tǒng)的 “心臟”,其穩(wěn)定性直接決定了整個照明設備的使用壽命。然而,在實際應用中,LED 驅(qū)動電源易損壞的問題卻十分常見,不僅增加了維護成本,還影響了用戶體驗。要解決這一問題,需從設計、生...

關(guān)鍵字: 驅(qū)動電源 照明系統(tǒng) 散熱

根據(jù)LED驅(qū)動電源的公式,電感內(nèi)電流波動大小和電感值成反比,輸出紋波和輸出電容值成反比。所以加大電感值和輸出電容值可以減小紋波。

關(guān)鍵字: LED 設計 驅(qū)動電源

電動汽車(EV)作為新能源汽車的重要代表,正逐漸成為全球汽車產(chǎn)業(yè)的重要發(fā)展方向。電動汽車的核心技術(shù)之一是電機驅(qū)動控制系統(tǒng),而絕緣柵雙極型晶體管(IGBT)作為電機驅(qū)動系統(tǒng)中的關(guān)鍵元件,其性能直接影響到電動汽車的動力性能和...

關(guān)鍵字: 電動汽車 新能源 驅(qū)動電源

在現(xiàn)代城市建設中,街道及停車場照明作為基礎設施的重要組成部分,其質(zhì)量和效率直接關(guān)系到城市的公共安全、居民生活質(zhì)量和能源利用效率。隨著科技的進步,高亮度白光發(fā)光二極管(LED)因其獨特的優(yōu)勢逐漸取代傳統(tǒng)光源,成為大功率區(qū)域...

關(guān)鍵字: 發(fā)光二極管 驅(qū)動電源 LED

LED通用照明設計工程師會遇到許多挑戰(zhàn),如功率密度、功率因數(shù)校正(PFC)、空間受限和可靠性等。

關(guān)鍵字: LED 驅(qū)動電源 功率因數(shù)校正

在LED照明技術(shù)日益普及的今天,LED驅(qū)動電源的電磁干擾(EMI)問題成為了一個不可忽視的挑戰(zhàn)。電磁干擾不僅會影響LED燈具的正常工作,還可能對周圍電子設備造成不利影響,甚至引發(fā)系統(tǒng)故障。因此,采取有效的硬件措施來解決L...

關(guān)鍵字: LED照明技術(shù) 電磁干擾 驅(qū)動電源

開關(guān)電源具有效率高的特性,而且開關(guān)電源的變壓器體積比串聯(lián)穩(wěn)壓型電源的要小得多,電源電路比較整潔,整機重量也有所下降,所以,現(xiàn)在的LED驅(qū)動電源

關(guān)鍵字: LED 驅(qū)動電源 開關(guān)電源

LED驅(qū)動電源是把電源供應轉(zhuǎn)換為特定的電壓電流以驅(qū)動LED發(fā)光的電壓轉(zhuǎn)換器,通常情況下:LED驅(qū)動電源的輸入包括高壓工頻交流(即市電)、低壓直流、高壓直流、低壓高頻交流(如電子變壓器的輸出)等。

關(guān)鍵字: LED 隧道燈 驅(qū)動電源
關(guān)閉