IEnlistmentNotification Interface

Definitie

Beschrijft een interface die een Resource Manager moet implementeren om callbacks voor doorvoermeldingen voor de transactiebeheerder twee fasen te bieden wanneer deze wordt ingeschreven voor deelname.

public interface class IEnlistmentNotification
public interface IEnlistmentNotification
type IEnlistmentNotification = interface
Public Interface IEnlistmentNotification
Afgeleid

Voorbeelden

In het volgende voorbeeld ziet u een implementatie van deze interface, evenals het inschakelen van het object als deelnemer aan een transactie met behulp van de EnlistVolatile methode.

static void Main(string[] args)
{
    try
    {
        using (TransactionScope scope = new TransactionScope())
        {
        
            //Create an enlistment object
            myEnlistmentClass myElistment = new myEnlistmentClass();

            //Enlist on the current transaction with the enlistment object
            Transaction.Current.EnlistVolatile(myElistment, EnlistmentOptions.None);

            //Perform transactional work here.

            //Call complete on the TransactionScope based on console input
                            ConsoleKeyInfo c;
            while(true)
                            {
                Console.Write("Complete the transaction scope? [Y|N] ");
                c = Console.ReadKey();
                Console.WriteLine();
        
                                    if ((c.KeyChar == 'Y') || (c.KeyChar == 'y'))
                {
                    scope.Complete();
                    break;
                }
                else if ((c.KeyChar == 'N') || (c.KeyChar == 'n'))
                {
                    break;
                }
            }
        }
    }
    catch (System.Transactions.TransactionException ex)
    {
        Console.WriteLine(ex);
    }
    catch
    {
        Console.WriteLine("Cannot complete transaction");
        throw;
    }
}

class myEnlistmentClass : IEnlistmentNotification
{
    public void Prepare(PreparingEnlistment preparingEnlistment)
    {
        Console.WriteLine("Prepare notification received");

        //Perform transactional work

        //If work finished correctly, reply prepared
        preparingEnlistment.Prepared();

        // otherwise, do a ForceRollback
        preparingEnlistment.ForceRollback();
    }

    public void Commit(Enlistment enlistment)
    {
        Console.WriteLine("Commit notification received");

        //Do any work necessary when commit notification is received

        //Declare done on the enlistment
        enlistment.Done();
    }

    public void Rollback(Enlistment enlistment)
    {
        Console.WriteLine("Rollback notification received");

        //Do any work necessary when rollback notification is received

        //Declare done on the enlistment
        enlistment.Done();
    }

    public void InDoubt(Enlistment enlistment)
    {
        Console.WriteLine("In doubt notification received");

        //Do any work necessary when indout notification is received
        
        //Declare done on the enlistment
        enlistment.Done();
    }
}
    Public Shared Sub Main()
        Try
            Using scope As TransactionScope = New TransactionScope()

                'Create an enlistment object
                Dim myEnlistmentClass As New EnlistmentClass

                'Enlist on the current transaction with the enlistment object
                Transaction.Current.EnlistVolatile(myEnlistmentClass, EnlistmentOptions.None)

                'Perform transactional work here.

                'Call complete on the TransactionScope based on console input
                Dim c As ConsoleKeyInfo
                While (True)
                    Console.Write("Complete the transaction scope? [Y|N] ")
                    c = Console.ReadKey()
                    Console.WriteLine()
                    If (c.KeyChar = "Y") Or (c.KeyChar = "y") Then
                        scope.Complete()
                        Exit While
                    ElseIf ((c.KeyChar = "N") Or (c.KeyChar = "n")) Then
                        Exit While
                    End If
                End While
            End Using
        Catch ex As TransactionException
            Console.WriteLine(ex)
        Catch
            Console.WriteLine("Cannot complete transaction")
            Throw
        End Try
    End Sub
End Class

Public Class EnlistmentClass
    Implements IEnlistmentNotification

    Public Sub Prepare(ByVal myPreparingEnlistment As PreparingEnlistment) Implements System.Transactions.IEnlistmentNotification.Prepare
        Console.WriteLine("Prepare notification received")

        'Perform transactional work

        'If work finished correctly, reply with prepared
        myPreparingEnlistment.Prepared()
    End Sub

    Public Sub Commit(ByVal myEnlistment As Enlistment) Implements System.Transactions.IEnlistmentNotification.Commit
        Console.WriteLine("Commit notification received")

        'Do any work necessary when commit notification is received

        'Declare done on the enlistment
        myEnlistment.Done()
    End Sub

    Public Sub Rollback(ByVal myEnlistment As Enlistment) Implements System.Transactions.IEnlistmentNotification.Rollback
        Console.WriteLine("Rollback notification received")

        'Do any work necessary when rollback notification is received

        'Declare done on the enlistment
        myEnlistment.Done()
    End Sub

    Public Sub InDoubt(ByVal myEnlistment As Enlistment) Implements System.Transactions.IEnlistmentNotification.InDoubt
        Console.WriteLine("In doubt notification received")

        'Do any work necessary when indout notification is received

        'Declare done on the enlistment
        myEnlistment.Done()
    End Sub
End Class

Opmerkingen

Als u wilt dat een resourcemanager deelneemt aan een transactie, moet deze de transactie inschakelen via de transactiebeheerder. De Transaction klasse definieert een set methoden waarvan de namen beginnen met Enlist die deze functionaliteit bieden. De verschillende Enlist methoden komen overeen met de verschillende typen aanmelding die een resourcemanager kan hebben.

In deze klasse wordt een interface beschreven die een Resource Manager moet implementeren om callbacks voor melding van twee fasen door te voeren voor de transactiebeheerder wanneer deze wordt ingeschreven voor deelname. Voor de implementatie van elke resourcemanager van de IEnlistmentNotification interface moet u deze inschakelen met behulp van de EnlistVolatile methode of de EnlistDurable methode van de Transaction klasse, afhankelijk van of uw resource vluchtig of duurzaam is. Zie Voor meer informatie over opname en 2PC resources als deelnemers aan een transactie en het doorvoeren van een transactie in respectievelijk Single-Phase en meerdere fasen .

De transactiebeheerder meldt het in de lijst geplaatste object in verschillende fasen van het Protocol voor twee fasen doorvoeren door de volgende methoden.

Methode Beschrijving
Prepare Deze methode van een in de lijst geplaatst object wordt gebruikt als een callback door Transaction Manager tijdens de eerste fase van een transactie, wanneer de transactiebeheerder deelnemers vraagt of ze de transactie kunnen doorvoeren.
Commit Deze methode van een in de lijst geplaatst object wordt gebruikt als een callback door Transaction Manager tijdens de tweede fase van een transactie als de transactie wordt doorgevoerd.
Rollback Deze methode van een in de lijst geplaatst object wordt gebruikt als een callback door Transaction Manager tijdens de tweede fase van een transactie als de transactie wordt afgebroken (dat wil gezegd teruggedraaid).
InDoubt Deze methode van een opgenomen object wordt gebruikt als een callback door Transaction Manager tijdens de tweede fase van een transactie als de transactie twijfelt.

Note

U moet er rekening mee houden dat meldingen mogelijk niet opeenvolgend of in een bepaalde volgorde worden verzonden.

Methoden

Name Description
Commit(Enlistment)

Hiermee wordt een in een lijst geplaatst object aangegeven dat een transactie wordt doorgevoerd.

InDoubt(Enlistment)

Hiermee wordt een in een lijst opgenomen object aangegeven dat de status van een transactie twijfelachtig is.

Prepare(PreparingEnlistment)

Hiermee wordt een in een lijst geplaatst object aangegeven dat een transactie wordt voorbereid op toezegging.

Rollback(Enlistment)

Hiermee wordt een in een lijst geplaatst object aangegeven dat een transactie wordt teruggedraaid (afgebroken).

Van toepassing op

Zie ook