Escalation della gestione delle transazioni

In Windows è disponibile un gruppo di servizi e moduli che costituisce un gestore transazioni. L'escalation della gestione delle transazioni consiste nel migrare una transazione da un componente del gestore transazioni a un altro.

Lo spazio dei nomi System.Transactions comprende un componente del gestore transazioni finalizzato a coordinare una transazione che prevede al più un'unica risorsa durevole o più risorse volatili. Il gestore transazioni offre le migliori prestazioni, in quanto esegue chiamate che riguardano esclusivamente un determinato dominio applicazione. Gli sviluppatori possono evitare di interagire direttamente con il gestore transazioni, in quanto lo spazio dei nomi System.Transactions fornisce un'infrastruttura comune che definisce interfacce, comportamenti comuni e classi helper.

Quando si desidera passare la transazione a un altro oggetto contenuto in un altro dominio applicazione dello stesso computer, in un altro processo o in un altro computer, l'infrastruttura System.Transactions esegue automaticamente l'escalation della transazione in modo che venga gestita dal gestore MSDTC (Microsoft Distributed Transaction Coordinator). L'escalation si verifica anche quando si integra un altro gestore di risorse durevoli. Dopo l'escalation, la transazione viene gestita nello stato superiore fino al suo completamento.

Fra la transazione dello spazio dei nomi System.Transactions e la transazione MSDTC esiste un tipo intermedio di transazione reso disponibile tramite l'integrazione PSPE (Promotable Single Phase Enlistment), ovvero un altro importante meccanismo dello spazio dei nomi System.Transactions finalizzato all'ottimizzazione delle prestazioni. L'integrazione PSPE consente a una risorsa durevole remota appartenente a un altro dominio applicazione, processo o computer di partecipare a una transazione dello spazio dei nomi System.Transactions senza comportarne l'escalation a una transazione MSDTC. Per ulteriori informazioni su PSPE, vedere Integrazione di risorse come partecipanti a una transazione.

Condizioni e modalità di avvio delle escalation

L'escalation delle transazioni riduce le prestazioni in quanto il gestore MSDTC risiede in un processo a parte. Inoltre, l'escalation di una transazione al gestore MSDTC comporta l'invio di messaggi fra i processi. Per migliorare le prestazioni è necessario ritardare o evitare l'escalation al gestore MSDTC. È pertanto opportuno conoscere le condizioni e le modalità di avvio delle escalation.

Finché l'infrastruttura System.Transactions gestisce risorse volatili e al massimo una risorsa durevole che supporta le notifiche monofase, la transazione resta proprietà dell'infrastruttura System.Transactions. Il gestore transazioni utilizza soltanto le risorse che risultano attive nello stesso dominio applicazione e per cui non è necessario eseguire la registrazione, ovvero la scrittura su disco del risultato della transazione. Le escalation che comportano il trasferimento della proprietà di una transazione dall'infrastruttura System.Transactions al gestore MSDTC si verificano nei casi seguenti:

  • Almeno una risorsa durevole che non supporta le notifiche monofase viene integrata nella transazione.

  • Almeno due risorse durevoli che supportano le notifiche monofase vengono integrate nella transazione. Ad esempio, l'integrazione di una sola connessione a un database non comporta l'escalation di una transazione. Tuttavia, quando si apre una seconda connessione a un database che ne comporta l'integrazione, l'infrastruttura System.Transactions rileva che la transazione presenta due risorse durevoli e quindi ne esegue l'escalation a transazione MSDTC.

  • Si verifica una richiesta di "marshalling" della transazione a un altro dominio applicazione o processo. Si consideri ad esempio il caso della serializzazione di un oggetto di transazione passato attraverso il confine di un dominio applicazione. In tal caso il sistema esegue il marshalling dell'oggetto di transazione per valore: se si tenta di passare tale oggetto attraverso il confine di un dominio applicazione (anche nello stesso processo), l'oggetto di transazione viene serializzato. È possibile passare gli oggetti di transazione effettuando una chiamata a un metodo remoto che accetta come parametro un oggetto Transaction. In alternativa, è possibile tentare di accedere a un componente remoto che supporta le transazioni. Ciò comporta la serializzazione dell'oggetto di transazione nonché un'escalation, analogamente al caso di serializzazione di una transazione passata attraverso il confine di un dominio applicazione. Ciò si verifica in quanto la transazione viene distribuita e quindi il gestore transazioni locali non è più adeguato.

Nella tabella seguente sono elencate tutte le eccezioni che possono essere generate durante un'escalation.

Tipo di eccezione Condizione

InvalidOperationException

Tentativo di escalation di una transazione con livello di isolamento uguale a Snapshot.

TransactionAbortedException

Il gestore transazioni non è disponibile.

TransactionException

L'escalation non riesce e l'applicazione viene interrotta.

Footer image

Copyright © 2007 Microsoft Corporation. Tutti i diritti riservati.