FLUTE通信協(xié)議原理構(gòu)架
FLUTE 和 ALC 最大的差異點,是增加了 FDT。FDT 是附屬于 FLUTE session 的一個數(shù)據(jù)結(jié)構(gòu),里面記錄了被傳送的 ALC 對象的檔案屬性。以下是 FDT 內(nèi)可為每個檔案記錄的信息:
● 檔案 ID: 指的是代表一個檔案的 URI (Uniform Resource Identifier,通用資源標(biāo)志符號),檔案的名稱包含在 URI 內(nèi)。
● 檔案類型: 格式為 MIME (Multipurpose Internet Mail Extensions,多用途 Internet 郵件擴(kuò)展) 所定義的媒體類型。
● 檔案內(nèi)容: 即 ALC 物件的 TOI。
● 檔案的編碼方式: DVB-IPDC CDP 標(biāo)準(zhǔn)允許檔案經(jīng)過 GZip (GNU Zip) 壓縮后才放入 ALC 對象內(nèi)。
● 檔案的原始長度。
● 檔案編碼后的長度。
● 檔案安全信息: 如數(shù)字摘要信息 (digital digest) 或數(shù)字簽章 (digital signature)。
FLUTE 傳送端該怎么將 FDT 傳送給 FLUTE 接收端呢?答案是透過一種叫 FDT instance (FDT 實例) 的 ALC 對象。跟一般 ALC 對象不同的是,F(xiàn)DT instance 的 TOI 永遠(yuǎn)為 零,至于 FLUTE session 內(nèi)其它的 ALC 對象,TOI 會被指定為其它大于 零 的值。每個 FDT instance 里面會包含 FDT 中一個檔案以上的屬性信息,也有可能會包含 FDT 所有檔案的屬性信息。而且,同一個 FDT instance 被允許在 FLUTE session 內(nèi)被重復(fù)傳送。為了區(qū)別同一個 FLUTE session 內(nèi)所傳送的 FDT instance,每個 FDT instance 都擁有一個獨一無二的 FDT instance ID; 這個 ID 被紀(jì)錄在 FLUTE 封包內(nèi)的 LCT 標(biāo)頭擴(kuò)充字段 (LCT header extension) - EXT_FDT 中,凡是 TOI 為 零 的 FLUTE 封包,都會包含這個標(biāo)頭擴(kuò)充字段。
FDT-Instance 元素內(nèi)所包含的 File 元素,則描述了 FLUTE session 內(nèi)某個 ALC 對象的檔案屬性。舉例來說,圖5中的第一個 File 元素,里面所包含的是 FLUTE session 中,TOI 為 1 的 ALC 對象的檔案屬性。File元素內(nèi)的 Content-Location 屬性,是一個 URI,為代表該檔案的 ID。Content-Type 屬性標(biāo)示的是檔案的 MIME 媒體類型。Content-Length 屬性則為檔案編碼前的原始長度。
另外,F(xiàn)DT-Instance元素所包含的屬性,也有可能是 FDT instance 內(nèi)所有的 File 元素共通的預(yù)設(shè)屬性。例如: 當(dāng)與 FEC-OTI 相關(guān)的屬性被放在 FDT-Instance 元素時,表示這些屬性是FDT instance 內(nèi)所有 File 元素的預(yù)設(shè)屬性。反之,當(dāng) FEC-OTI 的相關(guān)屬性被放在 File 元素時,則表示這些屬性是專屬于該檔案的屬性,而且,F(xiàn)ile 元素內(nèi)的 FEC-OTI 可覆蓋FDT-Instance元素所指定的預(yù)設(shè)屬性。
在此附帶一提的是,一個 ALC 對象的 FEC-OTI,除了可放在 FDT instance 中傳送之外,也可放在傳送該 ALC 對象的 FLUTE 封包中傳送。有一種 FLUTE 封包內(nèi)的 LCT 標(biāo)頭擴(kuò)充字段 - EXT_FTI,是用來傳送 ALC 對象的 FDT-OTI 信息的。由于每個 ALC 對象所需的 FDT-OTI 信息,是由 ALC 對象所實行的 FEC 算法 (FEC encoding ID) 決定的,因此,傳送 ALC 對象的 FLUTE 封包內(nèi),EXT_FTI 標(biāo)頭擴(kuò)充字段的實際格式,也是由 FEC 算法決定的?;旧希現(xiàn)DT instance 的 FEC-OTI 一定要透過 EXT_FTI 來傳送。但是一般的 ALC 對象,就可以選擇要用 EXT_FTI 或 FDT instance 來傳送該 ALC 對象的 FEC-OTI; 不過,不管采用哪種方式,被傳送的 FEC-OTI,在格式和內(nèi)容上都必須是一樣的。
最后,我們來談一下 FLUTE 接收端如何由收到的 FDT instance,還原 FLUTE session 的 FDT 數(shù)據(jù)結(jié)構(gòu)。通常,在接收端會有一個動態(tài)的 FDT 數(shù)據(jù)庫 (FDT database)。在 FDT 數(shù)據(jù)庫中,每一個正在被接收的 FLUTE session,都會有一個相對應(yīng)的表格 (table),表格內(nèi)儲存了 FLUTE session 中所傳送之檔案的檔案屬性。因為從檔案路徑 (URI) 來搜尋檔案是一般檔案系統(tǒng)的慣例,因此,這個表格的主索引鍵 (primary key) 是檔案的 ID,而不是 ALC 對象的 TOI。
當(dāng) FLUTE 接收端每收到一個 FLUTE session 的 FDT instance,就會將其中包含的檔案之屬性,連同 FDT instance 的 ID 及FDT-Instance 元素的 Expires 屬性,一起記錄在該 FLUTE session 的表格中。若 FDT instance 內(nèi)所包含的檔案 ID,已經(jīng)存在表格中,此時需要比較收到的 FDT instance 之 ID,與表格中該檔案 ID 所記錄的 FDT instance ID。只有當(dāng)表格中所記錄的 FDT instance ID,小于收到的 FDT instance 之 ID 時,表格中關(guān)于該檔案的屬性才需要被更新。事實上,這也是 FLUTE 用來更新一個檔案的版本的方式; 當(dāng)一個 FLUTE 所傳送的檔案之內(nèi)容發(fā)生改變時,該檔案的 ID 不變,但 TOI 會改變,以指向另一個不同的 ALC 物件。
要判斷一個 FLUTE session 中的檔案已經(jīng)被刪除,有以下兩種方式: 1、表格中的檔案已超過 FDT-Instance 元素的 Expires 屬性所指定時間。2、接收到一個新的 FDT instance (意即 FDT instance ID 更高),其 FDT-Instance 元素的 Complete 屬性被設(shè)定為真,因此,不在這個新收到的 FDT instance 內(nèi)的檔案,都會被刪除。另外,在 FLUTE 標(biāo)準(zhǔn)內(nèi)也要求,針對同一個 ALC 對象 (TOI 相同) 的檔案屬性,在未來 FDT instance ID 更大的 FDT instance 中,只能加入和原有屬性不會產(chǎn)生矛盾的新檔案屬性。因此,在 DVB-IPDC CDP 標(biāo)準(zhǔn)中規(guī)定,若一個檔案的屬性存在于兩個不同的 FDT instance 中,而且,在這兩個 FDT instance 中的該檔案,使用的是相同的 TOI,則該檔案的刪除時間為兩個 FDT instance 中,Expires 屬性所指定的時間比較晚的那一個。
還有一點需要注意的是,不同的 FLUTE 接收端,若接收同一個 FLUTE session,因為開始接收的時間可能不同,實際的接收條件 (FLUTE 封包的遺失或錯誤狀況) 也可能不同,所以,F(xiàn)DT 數(shù)據(jù)庫內(nèi)該 FLUTE session 表格的內(nèi)容,也可能會有所不同。
評論