SQL Server分布式事务的适用环境与问题的解答
2010-07-14 08:59:20我们今天主要向大家讲述的是SQL Server分布式事务的正确解决方案,还有对其在实际操作中值得我们大家注意的问题的介绍。
此文章主要向大家讲述的是SQL Server分布式事务的正确解决方案,以及对其在实际操作中起适应的工作环境,以及对其实际操作中出现的问题的描述,以下就是文章的主要内容的详细描述,望大家在浏览之后会对其有更深的了解。
适用环境
操作系统:windows 2003
数据库:SQL Server 2000/SQL Server 2003
使用链接 服务器 进行远程数据库访问的情况
一、 问题现象
在执行SQL Server分布式事务时,在SQL Server 2005下收到如下错误:
消息 7391,级别 16,状态 2,过程 xxxxx,第 16 行
无法执行该操作,因为链接服务器 “xxxxx” 的 OLE DB 访问接口 “SQLNCLI” 无法启动SQL Server分布式事务。
在SQL Server 2000下收到如下错误:
该操作未能执行,因为 OLE DB 提供程序 ‘SQLOLEDB’ 无法启动分布式事务。
[OLE/DB provider returned message: 新事务不能登记到指定的事务处理器中。 ]
OLE DB 错误跟踪[OLE/DB Provider ‘SQLOLEDB’ ITransactionJoin::JoinTransaction returned 0x8004d00a]。
二、 解决方案
1. 双方启动MSDTC服务
MSDTC服务提供分布式事务服务,如果要在数据库中使用SQL Server分布式事务,必须在参与的双方服务器启动MSDTC(Distributed Transaction Coordinator)服务。
2. 打开双方135端口
MSDTC服务依赖于RPC(Remote Procedure Call (RPC))服务,RPC使用135端口,保证RPC服务启动,如果服务器有防火墙,保证135端口不被防火墙挡住。
使用“telnet IP 135 ”命令测试对方端口是否对外开放。也可用端口扫描软件(比如Advanced Port scanner)扫描端口以判断端口是否开放。
3. 保证链接服务器中语句没有访问发起事务服务器的操作
在发起事务的服务器执行链接服务器上的查询、视图或存储过程中含有访问发起事务服务器的操作,这样的操作叫做环回(loopback),是不被支持的,所以要保证在链接服务器中不存在此类操作。
4. 在事务开始前加入set xact_abort ON语句
对于大多数 OLE DB 提供程序(包括 SQL Server数据库),必须将隐式或显示事务中的数据修改语句中的 XACT_ABORT 设置为 ON。***不需要该选项的情况是在提供程序支持嵌套事务时。
5. MSDTC设置
打开“管理工具――组件服务”,以此打开“组件服务――计算机”,在“我的电脑”上点击右键。在MSDTC选项卡中,点击“安全配置”按钮。
在安全配置窗口中做如下设置:
l选中“网络DTC访问”
l在客户端管理中选中“允许远程客户端”“允许远程管理”
l在事务管理通讯中选“允许入站”“允许出站”“不要求进行验证”
l保证DTC登陆账户为:NT AuthorityNetworkService
6. 链接服务器和名称解析问题
建立链接SQL Server服务器,通常有两种情况:
l***种情况,产品选”SQL Server数据库”
以下是代码片段:

这种情况,@server (linkServerName)就是要链接的sqlserver服务器名或者ip地址。
l第二种情况,访问接口选“Microsoft OLE DB Provider SQL Server”或“Sql Native Client”
以下是代码片段:
这种情况,@Datasrc(sqlServerName)就是要链接的实际sqlserver服务器名或者ip地址。
SQL Server数据库引擎是通过上面设置的服务器名或者ip地址访问链接服务器,DTC服务也是通过服务器名或者ip地址访问链接服务器,所以要保证数据库引擎和DTC都能通过服务器名或者ip地址访问到链接服务器。
【编辑推荐】
asp连接数据库错误
数据库路径错误。 你当前的这个与yxlove_在同一目录下。 如果不行就换一中连接方式:set conn=()db=(yxlove_) Provider=.4.0;Data Source= & db
EJB是啥玩意了
您现在可能已在使用 JavaBean,但还不了解它。 如果有支持 Java 的浏览器,那么,在桌面上使用 JavaBean 就没有限制。 使用的 Web 页面可以将 bean 作为小应用程序的一部分。 您很快就会和作为浏览器可视部分的 JavaBean 交互,然后,那些 JavaBean 将与服务器上的 EJB 接口。 这种能力也可以扩展到因特网和内部网。 JavaBean 和 Server Bean(通常称为 Enterprise JavaBean (EJB))有一些基本相同之处。 它们都是用一组特性创建,以执行其特定任务的对象或组件。 它们还有从当前所驻留服务器上的容器获得其它特性的能力。 这使得 bean 的行为根据特定任务和所在环境的不同而有所不同。 这开辟了巨大商机。 因为 JavaBean 是与平台无关的,所以对于将来的解决方案,供应商可以轻易向不同用户推出其客户机方的 JavaBean,而不必创建或维护不同的版本。 这些 JavaBean 可以与执行商业功能(例如订购、信用卡处理、电子汇款、存货分配、运输等)的 EJB 配合使用。 这里有巨大潜力,而这正是组件代理(WebSphereApplication Server 企业版)设计提供的那种潜力。 JavaBean 是一种组件,它在内部有接口或有与其相关的属性,以便不同人在不同时间开发的 bean 可以询问和集成。 可以构建一个 bean,而在以后构造时将其与其它 bean 绑定。 这种过程提供了先构建,然后重复使用的方法,这就是组件的概念。 可以将这种单一应用程序部署成独立程序、ActiveX组件或在浏览器中。 JavaBean 因其外部接口(即属性接口)而与纯对象不同。 这种接口允许工具读取组件要执行的功能,将其与其它 bean 挂钩,以及将其插入其它环境。 JavaBean 设计成对单一进程而言是本地的,它们在运行时通常可视。 这种可视组件可能是按钮、列表框、图形或图表 - 但这不是必需的。 可执行组件Server Bean 或 EJB 是部署在服务器上的可执行组件或商业对象。 有一个协议允许对其进行远程访问或在特定服务器上安装或部署它们。 有一系列机制允许它们将服务安全性、事务行为、并发性(由多个客户机同时访问的能力)和持久性(其状态可以保存多久)的主要方面授权给 EJB 服务器上其所在的容器。 当安装在容器中时,它们获得各自的行为,该行为提供不同质量的服务,因此,选择正确的 EJB 服务器至关重要。 这正是 IBM WebSphere 企业版的优势所在。 EJB 是设计成运行在服务器上,并由客户机调用的非可视远程对象。 可通过多个非可视 JavaBean 构建 EJB。 它们有一个部署描述符,其目的与 JavaBean 属性相同:它是以后可由工具读取的 bean 的描述。 EJB 还独立于平台,一旦编写好,还可以在任何支持 Java 的平台(包括客户机和服务器)上使用。 因为 EJB 由诸如 IBM VisualAge for Java 这样的工具集生成,所以,它是基于服务器的对象,并用于远程调用。 它们安装在 EJB 服务器上,并象调用其它 CORBA远程对象那样获得进行调用的远程接口。 ActiveX 对象可以将 JavaBean 部署成 ActiveX 对象,虽然 EJB 的代理也可以这样做,但是,因为 ActiveX 运行在桌面上,所以,EJB 本身不能成为 ActiveX 对象。 要在与平台相关的、仅 Windows 平台上做到这一点,开发人员可以将 JavaBean 变换成 ActiveX 组件。 好处EJB 的主要好处在于:构建 bean 时,bean 开发人员可以规定需要什么类型的行为,而不必规定如何去做。 开发分为两部分:程序员开发bean,然后验证:它可与构建工具一起工作,并包括标识所需服务质量行为种类的部署描述符。 下一步,另一个程序员可以采用这个 bean,并使用读取 EJB 部署描述符的部署工具,然后将该 bean 安装到 Enterprise Java Server 上的容器中。 在第二步中,部署工具采取一些操作 - 这可能意味着生成如状态保存代码,放入事务挂钩,或执行安全性检查这样的代码。 所有这些操作由部署工具生成,bean 开发人员和部署人员可以是不同的人。 可以通过使用部署工具,将任何独立于平台的 JavaBean 改写成具有可靠服务质量、特定于平台的 EJB,以满足现有商业系统和应用程序的特定需求。 这就是 EJB 服务器对集成系统、网络和体系结构如此重要的原因所在。 EJB 与 IBM WebSphere 企业版在 IBM WebSphere 企业版中使用时,可以将 EJB 配置成被管理的商业对象。 接受它们授权服务的容器是其安装到的容器。 将 EJB 的持久性部分映射在数据或状态对象中。 EJB 服务器为 EJB 提供不同的服务质量,选择正确的 EJB 服务器可能对满足完整的商业需求至关重要。 “组件代理”功能极其健壮,该功能提供如负载均衡和支持服务器组中多台机器的高级功能。 它还有大大超出 Enterprise Java Server (EJS) 规范所倡导的系统管理功能。 因此,按照基本标准编写的 JavaBean 或 EJB 可以运行在使用“组件代理”功能的 WebSphere 企业版上,并获得那些所有的附加功能。 EJB服务器还提供独特的特性和服务质量,而且不完全相同。 IBM“组件代理”有一些强大特性 - 例如,可伸缩性,它允许开发人员将 EJB 部署到从小型系统到大型网络的不同类型服务器。 开发人员可以从小处入手,例如,在一个部门中,首先在 LAN 的 Java 服务器上部署,一旦准备好,就知道可以将在那里创建的 JavaBean 和 EJB 部署到全球网络。 然后,开发人员可以测试并熟悉这些bean,试运行,制作样本等等。 满意之后,开发人员可以通过将其移至高性能服务器,来大幅度扩大其规模。 JavaBean 和 EJB 不受任何计算机体系结构边界的限制。 它们用 Java 编写,可以运行在任何具有 Java 虚拟机的系统上,并可以使用任何 Enterprise Java Server (EJS) 来部署对象。 因此,开发人员现在可以在方便的系统上构建,以后在方便的系统上部署,而不必是同一台或同样类型的机器。 IBM WebSphere 企业版支持将商业对象部署到多台服务器。 EJB 作为商业对象集成到“组件代理”功能,并作为任何其它商业对象处理。 因此,EJB 可以连接到所选的后端系统,并执行任何所需操作,以满足其商业需求。 这就成为“组件代理”为 EJB 提供的基础设施。 通过将“组件代理”用作 EJB 服务器,开发人员将能够继续使用当前旧有系统,并将其与电子商务接口一起提供。 为使 EJB 能在 WebSphere“组件代理”环境中工作,可以使用“组件代理”部署工具将其安装在一台或多台服务器上,然后将其添加到命名服务器,以便可以全局查找到它。 任何可以访问公共命名服务器的人都可以找到它,找到其宿主,并可以在宿主上执行方法,同时创建 EJB。 这就是“代理组件”要做的事。 结束语Bean 的全部意义不只是其现有能力,更在于其可以为商业提供的有竞争力的潜在能力。 IT 设计师和应用开发人员现在可以将精力完全集中在商业逻辑,而将如事务、持久性和安全性的底层工作留给服务器。 WebSphere 的“组件代理”功能将提供所有这些(还有后端访问)和对象事务管理器。
SQL Server 2005的有哪些新特点
看看官方的介绍吧:SQL Server 2005 新增功能企业数据管理在当今的互联世界中,数据和管理数据的系统必须始终为 用户可用且能够确保安全。 有了 SQL Server 2005,组织内的用户和信息技术 (IT) 专家将从减少的应用程序停机时间、提高的可伸缩性及 性能、更紧密而灵活的安全控制中获益。 SQL Server 2005 也包括了许多新的和改进的功能来帮助 IT 工作人员更有效率地工作。 SQL Server 2005 包含几个在企业数据管理中关键的增强:易管理性SQL Server 2005 使部署、管理和优化企业数据以及分析应用程序变得更简单、更容易。 作为一个企业数据管理平台,它提供单 一管理控制台,使数据管理员能够在任何地方监视、管理和调谐企业中所有的数据库和相关的服务。 它还提供了一个可以使用 SQL 管理对象轻松编程的可扩展 的管理基础结构,使得用户可以定制和扩展他们的管理环境,同时使独立软件供应商 (ISV) 也能够创建附加的工具和功能来更好地扩展打开即得的能力。 SQL Server Management StudioSQL Server 2005 通 过提供一个集成的管理控制台来监视和管理 SQL Server 关系数据库、Integration Services、 Analysis Services、Reporting Services、Notification Services 以及在数量众多的分布式服务 器和数据库上的 SQL Server Mobile Edition,从而简化了管理工作。 数据库管理员能够同时执行多个任务,例如,编写和执行查询, 查看服务器对象,管理对象,监视系统活动和查看联机帮助。 SQL Server Management Studio 提供了一个开发环境,可在其中使 用 Transact-SQL、多维表达式、XML for Analysis 和 SQL Server Mobile Edition 来编写、编辑 和管理脚本和存储过程。 Management Studio 可以很容易地与源代码控制集成在一起。 Management Studio 还包括一些工具 可用来调度 SQL Server 代理作业和管理维护计划,以自动执行日常维护和操作任务。 管理和脚本编写集成在单一工具中,同时,该工具具有管理所有 类型的服务器的能力,为数据库管理员们提供了更强的生产效率。 SQL Server 2005 开放了 70 多个新的内部数据库性能和 资源使用的度量值,涵盖了从内存、锁定到对事务、网络和磁盘 I/O 的调度等。 这些动态管理视图 (DMV) 提供了对数据库和强大的基础结构的更大的 透明度和可见性,可以主动监视数据库的状况和性能。 SQL 管理对象SQL 管理对象 (SMO) 是一个新的可编程对象集,它 可实现所有 SQL Server 数据库的管理功能。 事实上,Management Studio 就是构建在 SQL 管理对象之上的。 SMO 是作 为 Microsoft Framework 程序集实现的。 您可以使用 SMO 自动执行常见的 SQL Server 管理任务,例如,用 编程方式检索配置设置,创建新数据库,应用 Transact-SQL 脚本,创建 SQL Server 代理作业以及调度备份等。 SMO 对象模型替 代了包含在 SQL Server 早期版本中的分布式管理对象 (DMO),因为它更安全可靠并具有更高的可伸缩性。 可用性在 高可用性技术、额外的备份和恢复功能,以及复制增强上的投资使企业能够构建和部署高可用的应用程序。 在高可用性上的创新有:数据库镜像、故障转移群集、数 据库快照和增强的联机操作,这有助于最小化停机时间,并确保可以访问关键的企业系统。 本节将详细介绍这些增强特性。 数据库镜像数 据库镜像允许事务日志以连续的方式从源服务器传递到单台目标服务器上。 当主系统出现故障时,应用程序可以立即重新连接到辅助服务器上的数据库。 辅助实例几 秒钟内即可检测到主服务器发生了故障,并能立即接受数据库连接。 数据库镜像工作在标
发表评论