Maison >développement back-end >Tutoriel C#.Net >Explication détaillée d'exemples de Transactional File Manager

Explication détaillée d'exemples de Transactional File Manager

Y2J
Y2Joriginal
2017-04-25 09:12:302441parcourir

推荐一个文件事物管理 Gestionnaire de fichiers transactionnels

Description du projet

Le gestionnaire de fichiers transactionnels est une API .NET qui prend en charge les opérations du système de fichiers telles que la copie de fichiers, déplacer, supprimer, ajouter, etc. dans une transaction. Il s'agit d'une implémentation de System.Transaction.IEnlistmentNotification (fonctionne avec System.Transactions.TransactionScope).

Cette bibliothèque vous permet d'encapsuler les opérations du système de fichiers dans des transactions comme celle-ci :

// Wrap a file copy and a database insert in the same transactionTxFileManager fileMgr = new TxFileManager();using (TransactionScope scope1 = new TransactionScope())
{// Copy a file
fileMgr.Copy(srcFileName, destFileName);// Insert a database record
dbMgr.ExecuteNonQuery(insertSql);scope1.Complete();
}

Actuel Fonctionnalités

  • Prend en charge les opérations de fichiers suivantes dans les transactions :

    • AppendAllText

    • Copier

    • Créer un répertoire

    • Supprimer le répertoire

    • Supprimer le fichier

    • Déplacer

    • Instantané

    • WriteAllText

    • WriteAllBytes

Cette bibliothèque prend en charge n'importe quel système de fichiers et n'est pas un wrapper sur NTFS transactionnel (voir AlphaFS).

Exemples

// Completely unrealistic example showing how various file operations, including operations done // by library/3rd party code, can participate in transactions.IFileManager fileManager = new TxFileManager();using (TransactionScope scope1 = new TransactionScope())
{    fileManager.WriteAllText(inFileName, xml);    // Snapshot allows any file operation to be part of our transaction.
    // All we need to know is the file name.
    //The statement below tells the TxFileManager to remember the state of this file.
    // So even though XslCompiledTransform has no knowledge of our TxFileManager, the file it creates (outFileName)
    // will still be restored to this state in the event of a rollback.
    fileManager.Snapshot(outFileName);    XslCompiledTransform xsl = new XslCompiledTransform(true);    xsl.Load(uri);    xsl.Transform(inFileName, outFileName);    // write to database 1. This database op will get committed/rolled back along with the file operations we are doing in this transaction.
    myDb1.ExecuteNonQuery(sql1);    // write to database 2. The transaction is promoted to a distributed transaction here.
    myDb2.ExecuteNonQuery(sql2);    // let's delete some files
    for (string fileName in filesToDelete)
    {
        fileManager.Delete(fileName);
    }    // Just for kicks, let's start a new nested  transaction. Since we specify RequiresNew here, this nested transaction
    // will be committed/rolled back separately from the main transaction.
    // Note that we can still use the same fileManager instance. It knows how to sort things out correctly.
    using (TransactionScope scope2 = new TransactionScope(TransactionScopeOptions.RequiresNew))
    {        fileManager.MoveFile(anotherFile, anotherFileDest);
    }    // move some files
    for (string fileName in filesToMove)
    {
        fileManager.Move(fileName, GetNewFileName(fileName));
    }    // Finally, let's create a few temporary files...
    // disk space has to be used for something.
    // The nice thing about FileManager.GetTempFileName is that
    // The temp file will be cleaned up automatically for you when the TransactionScope completes.
    // No more worries about temp files that get left behind.
    for (int i=0; i<10; i++)
    {
        fileManager.WriteAllText(fileManager.GetTempFileName(), "testing 1 2");
    }    scope1.Complete();    // In the event an exception occurs, everything done here will be rolled back including the output xsl file.}

这是一个开源项目。原始项目网站是  事务文件管理器。

版权所有(c)2008-2013 Chinh Do

特此授予任何获得本软件和相关文档文件(«软件»)副本的人免费许可,无限制地处理本软件,包括但不限于使用,复制,修改,合并的权利,发布,分发,再授权和/或出售本软件的副本,并允许提供本软件的人员遵守以下条件:

上述版权声明和本许可声明应包含在本软件的所有副本或主要部分。

该软件“按原样”提供,不附带任何明示或暗示的保证,包括但不限于适销性, 适用于特定用途和不侵权的保证。在任何情况下,作者或版权所有者均不对任何索赔,损害或其他责任负责,无论是否因与本软件或本软件的使用或其他交易相关的任何合同,侵权行为或其他方面的行为软件。

Ce qui précède est le contenu détaillé de. pour plus d'informations, suivez d'autres articles connexes sur le site Web de PHP en chinois!

Déclaration:
Le contenu de cet article est volontairement contribué par les internautes et les droits d'auteur appartiennent à l'auteur original. Ce site n'assume aucune responsabilité légale correspondante. Si vous trouvez un contenu suspecté de plagiat ou de contrefaçon, veuillez contacter admin@php.cn