在分布式应用程序中,不可避免地会经常使用到事务控制。事务有一个开头和一个结尾,它们指定了事务的边界,事务在其边界之内可以跨越进程和计算机。事务边界内的所有资源都参与同一个事务。要维护事务边界内资源间的一致性,事务必须具备 ACID 属性,即原子性、一致性、隔离性和持续性。
本地事务和分布式事务 -------------------- 本地事务是其范围为单个可识别事务的数据资源的事务(例如,Microsoft SQL Server 数据库或 MSMQ 消息队列)。例如,当单个数据库系统拥有事务中涉及的所有数据时,就可以遵循 ACID 规则。在 SQL Server 的情况下,由内部事务管理器来实现事务的提交和回滚操作。
http://msdn.microsoft.com/library/en-us/cpguide/html/cpconDistributedTransactions.asp>; ),目前存在许多这样的应用程序,包括 MSMQ、Microsoft SQL Server、Oracle、Sybase 等等。
数据库事务 ------------- 如果调用一个在 BEGIN TRANSACTION 和 COMMIT/ROLLBACK TRANSACTION 语句中封装了所需操作的存储过程,您就可以在到数据库服务器的单个往返行程中运行事务,从而实现最佳性能。数据库事务还支持嵌套事务,这意味着您可以从一个活动事务中启动一个新事务。
在下面的代码片断中,BEGIN TRANSACTION 语句开始了一个新事务。可以通过使用 COMMIT TRANSACTION 语句将更改提交到数据库来结束事务,或者,在发生任何错误的情况下,通过使用 ROLLBACK TRANSACTION 语句将所有更改撤消来结束事务:
CREATE PROCEDURE Proc1 … AS -- Begin the transaction BEGIN TRANSACTION -- Do transaction operations … -- Check for any Error If @@Error <> 0 -- Rollback the Transaction ROLLBACK TRANSACTION … -- Commit the Transaction COMMIT TRANSACTION
手动事务 ------------- 利用手动事务,您可以使用开始和结束事务的显式指令来显式控制事务边界。此模式还支持允许您从活动事务中开始一个新事务的嵌套事务。但是,应用此控制会给您增加一种额外负担,您需要向事务边界登记数据资源并对这些资源进行协调。由于对分布式事务没有任何内置的支持,因此,如果您选择以手动方式来控制分布式事务,将承担许多责任;您需要控制每个连接和资源登记,并通过提供实现来保持事务的 ACID 属性。
ADO.NET 手动事务
这两种 Microsoft ADO.NET 数据提供程序通过提供创建到数据存储区的连接、开始一个事务、提交或中止事务以及最后关闭连接的一组对象来启用手动事务。我们将以 ADO.NET SQL 托管提供程序为例来进行说明。
要在单个事务中执行操作,您需要创建 SQLTransaction 对象、使用 SQLConnection 对象开始事务、确保在事务内进行数据库交互以及提交或中止事务。SQLTransaction 对象提供了多种方法和属性来控制事务。如果事务中的每个操作都已经成功完成,可以使用 “提交” 方法将所做的更改提交到数据库。使用 SQLTransaction 对象的 “回滚” 方法可以回滚更改。
注意 命令 对象的 Transaction 属性必须设置为一个已经开始的事务,这样,它才能在该事务中执行。
Visual C# .NET
SQLConnection Conn = New SQLConnection(ConnString); SQLCommand Cmd = New SQLCommand; // Open a connection Conn.Open(); // Begin a transaction SQLTransaction Txn = Conn.BeginTransaction(); // Set the Transaction in which the command executes Cmd.Transaction = Txn; …
MSMQ 手动事务
.NET Framework 以两种不同的方式支持 MSMQ 事务:通过允许多个消息作为事务的一部分发送或接收而手动(内部)支持;通过参与 Distributed Transaction Coordinator (DTC) 事务而自动(外部)支持。
http://msdn.microsoft.com/library/en-us/dnbda/html/bdadotnetasync2.asp>;
自动事务 ------------- .NET Framework 依靠 MTS/COM+ 服务来支持自动事务。COM+ 使用 Microsoft Distributed Transaction Coordinator (DTC) 作为事务管理器和事务协调器在分布式环境中运行事务。这样可使 .NET 应用程序运行跨多个资源结合不同操作(例如,将定单插入 SQL Server 数据库、将消息写入 Microsoft 消息队列 (MSMQ) 队列、发送电子邮件以及从 Oracle 数据库检索数据)的事务。
通过提供基于声明性事务的编程模型,COM+ 使应用程序可以很容易地运行跨不同种类的资源的事务。这种做法的缺点是,由于存在 DTC 和 COM 互操作性开销,导致性能降低,而且不支持嵌套事务。
ASP.NET 页、Web Service 方法和 .NET 类通过设置声明性事务属性都可以标记为事务性。
ASP.NET
<@ Page Transaction=Required>
ASP.NET Web 服务
<%@ WebService Language=VB Class=Class1 %> <%@ assembly name=System.EnterpriseServices %> … Public Class Class1 Inherits WebService <WebMethod(TransactionOption := TransactionOption.RequiresNew)> _ Public Function Method1() …
要参与自动事务,.NET 类必须是从 System.EnterpriseServices.ServicedComponent 类继承的,这可使得该 .NET 类能够在 COM+ 内运行。在这个过程中,要将 COM+ 与 DTC 进行交互以创建一个分布式事务,也要登记后台的所有资源连接。您还需要对该类设置声明性事务属性以确定其事务性行为。
Visual C# .NET [Transaction(TransactionOption.Required)] public class Class1 : ServicedComponent { … }
类的事务属性可以设置为以下任何选项: • “禁用” — 指示该对象从不在 COM+ 事务中创建。该对象可以直接使用 DTC 来获得事务性支持。 • NotSupported — 指示该对象从不在事务中创建。 • “支持” — 指示该对象在其创建者的事务的上下文中运行。如果该对象本身是根对象,或者其创建者不在事务中运行,则该对象将在不使用事务的情况下创建。 • “必选” — 指示对象在其创建者的事务的上下文中运行。如果该对象本身是根对象,或者其创建者不在事务中运行,则该对象将使用一个新事务来创建。 • RequiresNew — 指示该对象需要一个事务,并且该对象使用新事务来创建。
下面的代码显示了配置为在 COM+ 中运行、将程序集属性设置为配置 COM+ 应用程序属性的 .NET 类。
Visual C# .NET using System; using System.Runtime.CompilerServices; using System.EnterpriseServices; using System.Reflection; //Registration details. //COM+ application name as it appears in the COM+ catalog [Assembly: ApplicationName(Class1)] Strong name for assembly [Assembly: AssemblyKeyFileAttribute(class1.snk)] [Assembly: ApplicationActivation(ActivationOption.Server)] [Transaction(TransactionOption.Required)] public class Class1 : ServicedComponent { [AutoComplete] public void Example1() { … } }
指定要安装该程序集的组件的 COM+ 应用程序的名称。 指定 COM+ 应用程序是否为服务器应用程序或库应用程序。指定 ApplicationActivation(ActivationOption.Server)时,必须使用 gacutil 命令行工具 (GacUtil.exe) 将程序集安装到全局程序集缓存 (GAC)。
您可以使用 Regsvcs.exe 命令行工具将程序集转换为类型库,并将类型库注册和安装到指定的 COM+ 应用程序中。该工具还可用来配置您已经用编程方式添加到程序集中的属性。例如,如果在程序集中指定 ApplicationActivation(ActivationOption.Server),该工具将创建一个[1] [2] 下一页
|
.NET的事务控制
最新推荐文章于 2019-01-08 01:36:37 发布