當(dāng)前位置:首頁文章首頁 新聞中心

使用KTM(內(nèi)核事務(wù)管理器)進行文件事務(wù)處理

作者:  來源:  發(fā)布時間:2012-1-13 11:05:13  點擊:

在本人最近的幾篇關(guān)于事務(wù)處理的文章中,從事務(wù)處理的整體概念到具體的C#代碼的實踐操作基本上都已經(jīng)能滿足日常的開發(fā)需求。文章中大部分的事務(wù)范圍類的操作都是局限于數(shù)據(jù)庫,在本人的“.NET簡談自定義事務(wù)資源管理器 ”一文中我雖然實現(xiàn)了一個簡單的自定義資源管理器,其實也能滿足基本的項目需求,核心功能也實現(xiàn)了,但是對于文件事務(wù)操作我們是力不從心的。

從數(shù)據(jù)庫到自定義資源管理器都能參與到事務(wù)處理中來,在必要的時候保證數(shù)據(jù)的完整性,那么我們?nèi)币粋類型的資源操作,當(dāng)然您也許早就想問了,關(guān)于文件系統(tǒng)的事務(wù)操作怎么辦?那么關(guān)于文件的事務(wù)操作是否有成熟的解決方案了,這點在前幾年還真沒辦法,但是最近微軟已經(jīng)發(fā)布了關(guān)于事務(wù)性NTFS系統(tǒng)。都了解NTFS文件系統(tǒng)的優(yōu)勢和好處,比起FAT和其他的什么HPFS文件系統(tǒng)有極大的改進,所以文件事務(wù)處理僅支持NTFS格式的文件系統(tǒng)。

事務(wù)性NTFS也稱做TXF,只有最新的Windows系統(tǒng)才支持(WindowsVista\Windows7\WindowsServer2008\WindowsServer2008R2),所以在XP上就別測試了。

在前幾篇文章中都是使用的LTM本地事務(wù)管理器,然后進行事務(wù)范圍類的多個持久資源登記自動事務(wù)提升為DTC類型的事務(wù)操作,由于DTC是非托管的實現(xiàn),所以在分布式事務(wù)操作中會存在數(shù)據(jù)封送的性能損耗,MSDN也提倡盡量少用DTC處理,由于存在著很多不確定因素在遇到問題時比較棘手。但是在關(guān)鍵的時候還是需要這么用的,我們有必要去研究研究。

KTM、DTC、LTM三者的使用關(guān)系簡單介紹

以前的理解思路和講解的角度對于KTM來說是沒多大關(guān)系的,但是由于他的出現(xiàn)我們有必要回歸到原點進行重新的梳理來進行一個更加系統(tǒng)深入的理解,僅僅是理解;

在查詢了大量的MSDN文檔和對System.Transaction命名空間的仔細(xì)翻閱發(fā)現(xiàn)微軟隱藏了很多.NET事務(wù)實現(xiàn)細(xì)節(jié),比如System.Transaction.Oletx命名空間下的具體分布式協(xié)議的實現(xiàn)是沒有任何技術(shù)文檔看的,只能反編譯自己看代碼琢磨。

我們從LTM進行梳理,LTM是本地事務(wù)管理器那么他的存在只能在當(dāng)前的托管AppDomain中,不能夠夸遠(yuǎn)程處理,一旦跨遠(yuǎn)程處理負(fù)責(zé)傳播的對象就要實現(xiàn)對本地事務(wù)的提升功能,包括WCF中的一系列的banding元素和事務(wù)感知型代碼,都必須對事務(wù)進行管理,但是大部分的代碼都是系統(tǒng)提供的。

反編譯看了部分代碼,其中都會涉及到P\Invoke和COM\Interop之類的代碼,憑自己的理解它的目的是啟動IDTCTransaction接口,也就是COM接口。理解這一點對于我們下面的KTM操作非常有利。LTM要想進行DTC管理就必須通過OLE32.DLL進行COM接口的加載也就是我們托管的.NET類庫里面的IDTCTransaction接口,看一下代碼:

//  Describes a DTC transaction. 
    [Guid("0fb15084-af41-11ce-bd2b-204c4f4f5020")] 
    [InterfaceType(ComInterfaceType.InterfaceIsIUnknown)]
     public interface IDtcTransaction 

 

該接口是向COM公開時的類型,用作于COM互操作使用的,需要通過該接口進行DTC的提升使用;為了驗證理解是否正確我們來進行一個簡單的測試,我們手動的通過System.Transaction.TransactionInterop類來獲取非托管的IDTCTransaction接口,請看代碼:

LTM事務(wù):

public static void StartCopy() 
  {
      using (TransactionScope transcope = new TransactionScope())
        {
            transcope.Complete();         }    } 

 

 
這樣的代碼是不會提升為DTC管理的,我們加一行代碼:
 
public static void StartCopy()
 {
      using (TransactionScope transcope = new TransactionScope())
      {
         IDtcTransaction idtc = TransactionInterop.GetDtcTransaction(Transaction.Current);          transcope.Complete();
        }
   } 
先解釋一下TransactionInterop類的作用,來自MSDN的說明:

“促進System.Transactions 和以前編寫的用于與 MSDTC、COM+ 或 System.EnterpriseServices 進行交互的組件之間的交互。無法繼承此類。”

其實該類主要用來對早期的分布式事務(wù)技術(shù)進行互操作,比如用來獲取DTC相關(guān)的COM對象或者用來進行自定義的事務(wù)傳播,對于復(fù)雜的Oletx(Windows平臺的二進制通訊協(xié)議)協(xié)議,我們不需要關(guān)心太多核心的東西就能進行分布式事務(wù)的傳遞,這里可能Remoting有這個需求了。

利用TransactionInterop.GetDtcTransaction方法確實能獲取到DTC事務(wù)接口。

圖1:

有了TransactionInterop類,我們后面的擴展就方便多了。

由于KTM是屬于非托管實現(xiàn),操作系統(tǒng)提供了文件操作的事務(wù)性API方法:

非事務(wù)處理 API

事務(wù)處理 API

CreateFile

CreateFileTransacted

CopyFileEx

CopyFileTransacted

MoveFileWithProgress

MoveFileTransacted

DeleteFile

DeleteFileTransacted

CreateHardLink

CreateHardLinkTransacted

CreateSymbolicLink

CreateSymbolicLinkTransacted

CreateDirectoryEx

CreateDirectoryTransacted

RemoveDirectory

RemoveDirectoryTransacted

 通過封裝這些方法就能夠?qū)崿F(xiàn)事務(wù)性的文件操作,目前.NET沒有封裝成熟的類庫給我們使用,估計在后期的新版本類庫中可能會提供。

那么我們?nèi)绾问褂肒TM事務(wù)處理呢,很幸運的是通過MSND的連接我們能夠獲取到微軟的事務(wù)開發(fā)人員編寫的源碼,下載地址為:

http://download.microsoft.com/download/f/2/7/f279e71e-efb0-4155-873d-5554a0608523/TxF2007_07.exe

 源碼都是通過對上面的API進行封裝的,里面涉及到了很多關(guān)于內(nèi)部API和COM之間的通訊細(xì)節(jié),我們可以看看老外寫的代碼是復(fù)雜,也是我們學(xué)習(xí)的榜樣。

 上面我們說過只要夸當(dāng)前應(yīng)用程序域的事務(wù)處理就會自動提升為DTC事務(wù),對于API的調(diào)用已經(jīng)是出于互操作類型的,當(dāng)前已經(jīng)出于遠(yuǎn)程調(diào)用,DTC已經(jīng)具有與托管域的交互實現(xiàn),所以我們只有通過DTC進入KTM進行操作。這也是MSDN官方的解釋。

圖2:

我們來看一個簡單的例子,該例子實現(xiàn)對文件的事務(wù)性刪除操作。

例子1:

public static void StartDelete()
         {
             try             
{
                 using (TransactionScope transcope = new TransactionScope()) 
                {
                     Console.WriteLine("輸入要刪除的文件");
                     string path = Console.ReadLine();
                     Microsoft.KtmIntegration.TransactedFile.Delete(path);
                     Console.WriteLine("是否提交事務(wù)處理?"); 
                    if (Console.ReadLine() == "y")
                         transcope.Complete();
                     else 
                        Transaction.Current.Rollback(); 
                }
             }
             catch (Exception err) { Console.WriteLine(err); } 
 
我簡單的寫了一段測試代碼,經(jīng)過測試是OK的。KTM能很好的結(jié)合DTC、LTM進行混合的事務(wù)處理,對于我們上面引入的疑問現(xiàn)在能完美的解決了。

 王清培版權(quán)所有

相關(guān)軟件

相關(guān)文章

文章評論

軟件按字母排列: A B C D E F G H I J K L M N O P Q R S T U V W X Y Z