默认Sybase ASE安装是不支持XA的,必须从Sybase那里获取DTM License才可以。而且默认安装SYSAM服务也是不启动的,SYSAM服务是管理Sybase ASE内各种协议的服务。
DTM是
Distributed Transaction Management的简称。网上有专门的介绍Sybase DTM服务的文章《
Using Adaptive Server Distributed Transaction Management Features》,建议可以参考以下。
以下目录中出现“D:/ASE125
”是因为我的ASE安装在D:/ASE125目录下。
协议的修改是在 D:/ASE125/SYSAM-1_0/licenses/
license.dat文件中修改,Sybase安装后,默认内容是如下的:
INCREMENT ASE_SERVER SYBASE
12.0
permanent uncounted EC44123C6B70 HOSTID
=
ANY ck
=
50
SN
=
GA
这个内容是不完善的,所以造成刚安装后,SYSAM服务启动不了。
为了让SYSAM服务能够正常启动,你需要修改内容如下:
/*
在SERVER后紧跟的是机器名
*/
SERVER huchangcheng11 ANY 29722
VENDOR SYBASE D:ASE125SYSAM - 1_0inSYBASE.exe
USE_SERVER
INCREMENT ASE_SERVER SYBASE 12.0 permanent uncounted EC44123C6B70 HOSTID = huchangcheng11 ck = 50 SN = GA
SERVER huchangcheng11 ANY 29722
VENDOR SYBASE D:ASE125SYSAM - 1_0inSYBASE.exe
USE_SERVER
INCREMENT ASE_SERVER SYBASE 12.0 permanent uncounted EC44123C6B70 HOSTID = huchangcheng11 ck = 50 SN = GA
为了能够增加 DTM 协议的支持,还必须增加如下内容(下面仅是样例,不具有可执行性,具体协议号需要 Sybase 服务提供):
INCREMENT ASE_SERVER SYBASE
12.0
PERMANENT
1
EBB8DAACC019 SN
=
910589
-
1
OVERDRAFT
=
10000
ck
=
0
INCREMENT ASE_DTM SYBASE 12.0 PERMANENT 1 1EC3D299C12B SN = 897485 - 4 OVERDRAFT = 10000 ck = 0
INCREMENT ASE_DTM SYBASE 12.0 PERMANENT 1 1EC3D299C12B SN = 897485 - 4 OVERDRAFT = 10000 ck = 0
修改完协议后,重新启动数据库服务即可。在 D:/ASE125/ASE-12_5/install/ase125.log (具体 log 文件名称于所建的数据库名有关)日志文件中,查看信息,如果有如下信息,则表示 DTM 服务启动成功。
00:00000:00000:2006/09/26 15:37:25.45 kernel Use license file d:/ASE125/SYSAM-1_0/licenses/license.dat.
00:00000:00000:2006/09/26 15:37:25.45 kernel Feature ASE_SERVER is over drafted 1 times.
00:00000:00000:2006/09/26 15:37:25.45 kernel
Checked out license ASE_SERVER
00:00000:00000:2006/09/26 15:37:25.48 kernel Adaptive Server Enterprise Edition
00:00000:00000:2006/09/26 15:37:25.64 kernel Using config area from primary master device.
00:00000:00000:2006/09/26 15:37:25.69 kernel Warning: Using default file 'd:/ASE125/ase125.cfg' since a configuration file was not specified. Specify a configuration file name in the RUNSERVER file to avoid this message.
00:00000:00000:2006/09/26 15:37:25.71 kernel
Checked out license ASE_DTM
00:00000:00000:2006/09/26 15:37:25.90 kernel Using 100000 file descriptors.
00:00000:00000:2006/09/26 15:37:25.95 kernel Adaptive Server Enterprise/12.5.1/EBF 11428/P/NT (IX86)/OS 4.0/ase1251/1823/32-bit/OPT/Wed Sep 17 11:10:54 2003
00:00000:00000:2006/09/26 15:37:25.95 kernel Confidential property of Sybase, Inc.
00:00000:00000:2006/09/26 15:37:25.95 kernel Copyright 1987, 2003
00:00000:00000:2006/09/26 15:37:25.95 kernel Sybase, Inc. All rights reserved.
如果在启动日志中可以清楚地看到“
Checked out license ASE_DTM”,则表示DTM服务启动正常。
仅仅启动ASE_DTM服务的情况,依然不能获取XA事务支持的,必须给Login帐号设置dtm_tm_role角色才可以。这个不难,在Sybase Central中,选择ASE Server下的roles菜单,为dtm_tm_role角色设置Logins属性即可。
至此,Sybase ASE XA支持就可以了。