ansi_warning和ansi_nulls 两个选项必须打开,好像对系统也没啥影响。

 

楼主再检查一下两个地方,经测试,在要使用分布式事务时,这是必须要设置的。

1、链接服务器和名称解析问题

-- 创建链接服务器

EXEC sp_addlinkedserver 'srv_lnk', 'ms', 'SQLOLEDB', '192.168.1.1'

GO

-- 创建链接服务器上远程登录之间的映射

EXEC sp_addlinkedsrvlogin 'srv_lnk', 'false', NULL, 'sa', '123'

GO

在“C:\WINDOWS\system32\drivers\etc\hosts”文件中增加记录: 

xxx.xxx.xxx.xxx 服务器名

xxx.xxx.xxx.xxx 发起服务器名

2、防火墙设置

双方防火墙都添加例外程序c:\windows\system32\msdtc.exe

 

在计算机上已启用 Windows 防火墙。 默认情况下, Windows 防火墙阻止 MSDTC 程序。 

请注意 即使在关闭 Windows 防火墙,可能会出现此问题

------------------------------------------------------------------------------------

SQL Server 2005分布式事务环境搭建

 

一、 运行批处理程序,安装并启动msdtc服务

@echo off

setlocal

@echo %WINDIR%\System32\msdtc.exe -uninstall

%WINDIR%\System32\msdtc.exe -uninstall

call :delkey "HKCR\CID"

call :delkey "HKLM\SYSTEM\CurrentControlSet\Services\MSDTC"

call :delkey "HKLM\SYSTEM\ControlSet001\Services\MSDTC"

call :delkey "HKLM\SYSTEM\ControlSet002\Services\MSDTC"

call :delkey "HKLM\Software\Microsoft\MSDTC"

@echo %WINDIR%\System32\msdtc.exe -install

%WINDIR%\System32\msdtc.exe -install

endlocal

goto :EOF

:delkey

set key=%1

call :delkeyq %key% >nul 2>&1

@echo. 

goto :EOF

:delkeyq

REG Delete %key% /F

二、 打开双方防火墙中的35端口(Remote Procedure Call)

MSDTC服务依赖于RPC(Remote Procedure Call (RPC))服务,RPC使用135端口,保证RPC服务启动,如果服务器有防火墙,保证135端口不被防火墙挡住。 使用“telnet IP 135 ”命令测试对方端口是否对外开放。也可用端口扫描软件(比如Advanced Port Scanner)扫描端口以判断端口是否开放。

    在两个服务器上分别打开RPC OUT选项

 

Code:sql
1 
exec sp_serveroption 'test2005', 'rpc out', 'true

三、 保证链接服务器中语句没有访问发起事务服务器的操作

在发起事务的服务器执行链接服务器上的查询、视图或存储过程中含有访问发起事务服务器的操作,这样的操作叫做环回(loopback),是不被支持的,所以要保证在链接服务器中不存在此类操作。

四、 在事务开始前加入SET xact_abort ON语句

对于大多数 OLE DB 提供程序(包括 SQL Server),必须将隐式或显示事务中的数据修改语句中的 XACT_ABORT 设置为 ON。唯一不需要该选项的情况是在提供程序支持嵌套事务时。

 

五、 MSDTC设置

打开“管理工具――组件服务”,以此打开“组件服务――计算机”,在“我的电脑”上点击右键。在MSDTC选项卡中,点击“安全配置”按钮。 

在安全配置窗口中做如下设置: 

选中“网络DTC访问” 

在客户端管理中选中“允许远程客户端”、“允许远程管理” 

在事务管理通讯中选“允许入站”、“允许出站”、“不要求进行验证” 

保证DTC登陆账户为:NT Authority\NetworkService

----------------------------------------------------------------------------------------------------

-- 在发起服务器xiaodi(Windows XP)上建立链接服务器
EXEC sp_addlinkedserver 'cpserver', 'ms', 'SQLOLEDB', '75.81.1.220'
GO
EXEC sp_addlinkedsrvlogin 'cpserver', 'false', NULL, 'sa', '123'
GO
 
-- 在第二个服务器cpserver(Windows 2003 Server)上建立链接服务器
EXEC sp_addlinkedserver 'xiaodi', 'ms', 'SQLOLEDB', '75.81.2.37'
GO
EXEC sp_addlinkedsrvlogin 'xiaodi', 'false', NULL, 'sa', '123'
GO
 
-- 连接发起服务器xiaodi 75.81.2.37,创建存储过程
use ksoa_demo
GO
if exists(select top 1 1 from sysobjects where xtype='P' and name = 'dtc_test')
drop procedure dct_test
GO
create procedure dtc_test
as   set xact_abort ON   begin distributed tran dtc_test   update bmdoc set bm = '公司管理部1' where bmid = 'DBM00000001'   exec [test2005].ksoa_test_quyu.dbo.dtc_test   commit tran dtc_test   set xact_abort OFF
go
-- 连接第二个服务器cpserver 75.81.1.220,创建存储过程
use ksoa_test_quyu
GO
if exists(select top 1 1 from sysobjects where xtype='P' and name = 'dtc_test')
drop procedure dtc_test
GO
 
create procedure dtc_test
as   begin tran dtc_test1   update bmdoc set bm = '人力资源部1' where bmid = 'DBM00000053'   commit tran dtc_test1
go
-- 连接发起服务器xiaodi,执行存储过程
exec dtc_test
 
-- 查看结果
select * from [test2005].ksoa_test_quyu.dbo.bmdoc
select * from bmdoc
-- 注:如果第二个服务器cpserver上的语句执行失败,那么发起服务