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选项
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上的语句执行失败,那么发起服务器上的更新语句也将执行失败