IEnlistmentNotification Interface
Definitie
Belangrijk
Bepaalde informatie heeft betrekking op een voorlopige productversie die aanzienlijk kan worden gewijzigd voordat deze wordt uitgebracht. Microsoft biedt geen enkele expliciete of impliciete garanties met betrekking tot de informatie die hier wordt verstrekt.
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). |