在SQL Server 2000里设置和使用数据库复制之前,应先检查相关的几台SQL Server服务器下面几点是否满足:tUJTechFeel
tUJTechFeel
1、MSSQLserver和Sqlserveragent服务是否是以域用户身份启动并运行的(.\administrator用户也是可以的)tUJTechFeel
tUJTechFeel
如果登录用的是本地系统帐户local,将不具备网络功能,会产生以下错误:tUJTechFeel
tUJTechFeel
进程未能连接到Distributor '@Server name' tUJTechFeel
tUJTechFeel
(如果您的服务器已经用了SQL Server全文检索服务, 请不要修改MSSQLserver和Sqlserveragent服务的local启动。tUJTechFeel
会照成全文检索服务不能用。请换另外一台机器来做SQL Server 2000里复制中的分发服务器。) tUJTechFeel
tUJTechFeel
修改服务启动的登录用户,需要重新启动MSSQLserver和Sqlserveragent服务才能生效。 tUJTechFeel
tUJTechFeel
2、检查相关的几台SQL Server服务器是否改过名称(需要srvid=0的本地机器上srvname和datasource一样)tUJTechFeel
tUJTechFeel
在查询分析器里执行:tUJTechFeel
use mastertUJTechFeel
select srvid,srvname,datasource from sysservers tUJTechFeel
tUJTechFeel
如果没有srvid=0或者srvid=0(也就是本机器)但srvname和datasource不一样, 需要按如下方法修改:tUJTechFeel
tUJTechFeel
USE mastertUJTechFeel
GOtUJTechFeel
-- 设置两个变量tUJTechFeel
DECLARE @serverproperty_servername varchar(100), tUJTechFeel
@servername varchar(100)tUJTechFeel
-- 取得Windows NT 服务器和与指定的 SQL Server 实例关联的实例信息tUJTechFeel
SELECT @serverproperty_servername = CONVERT(varchar(100), SERVERPROPERTY('ServerName'))tUJTechFeel
-- 返回运行 Microsoft SQL Server 的本地服务器名称tUJTechFeel
SELECT @servername = CONVERT(varchar(100), @@SERVERNAME)tUJTechFeel
-- 显示获取的这两个参数tUJTechFeel
select @serverproperty_servername,@servernametUJTechFeel
--如果@serverproperty_servername和@servername不同(因为你改过计算机名字),再运行下面的tUJTechFeel
--删除错误的服务器名tUJTechFeel
EXEC sp_dropserver @server=@servernametUJTechFeel
--添加正确的服务器名tUJTechFeel
EXEC sp_addserver @server=@serverproperty_servername, @local='local'tUJTechFeel
tUJTechFeel
修改这项参数,需要重新启动MSSQLserver和Sqlserveragent服务才能生效。 tUJTechFeel
tUJTechFeel
这样一来就不会在创建复制的过程中出现18482、18483错误了。tUJTechFeel
tUJTechFeel
3、检查SQL Server企业管理器里面相关的几台SQL Server注册名是否和上面第二点里介绍的srvname一样tUJTechFeel
tUJTechFeel
不能用IP地址的注册名。tUJTechFeel
tUJTechFeel
(我们可以删掉IP地址的注册,新建以SQL Server管理员级别的用户注册的服务器名)