公司有一个老系统,这个系统所用的数据库是SQL SERVER 2000,它所在的Dell服务器已经运行超过10年了,早已经过了保修服务期,最近几乎每周会出现一次故障,加之5月份另外一台服务器坏了两个硬盘,所以非常担心这台服务器“寿终正寝”,跟开发维护那边沟通,想将数据库迁移升级到SQL SERVER 2008,但是由于是老旧系统,现在的负责人不敢做数据库升级,最终协商下来,只能迁移到另外一台服务器,不做升级。
在部署测试环境时,先将master,msdb等系统数据库直接拷贝过去覆盖原系统数据库,启动数据库后,出现了莫名错误。不得已只能从生产库备份master后在测试库还原,然后莫名的错误解决了(之前没有截图,记录下来),但是启动SQL SERVER代理服务器时,出现下面错误。
在目录C:Program FilesMicrosoft SQL ServerMSSQLLOG下找到SQLAGENT.OUT错误日志文件,发现如下错误提示:
2013-09-20 09:46:12 - ! [298] SQLServer 错误: 229,EXECUTE permission denied on object 'sp_sqlagent_has_server_access', database 'msdb', owner 'dbo'. [SQLSTATE 42000] (ConnIsLoginSysAdmin) 2013-09-20 09:46:12 - ! [298] SQLServer 错误: 229,EXECUTE permission denied on object 'sp_sqlagent_get_startup_info', database 'msdb', owner 'dbo'. [SQLSTATE 42000] 2013-09-20 09:46:12 - ? [100] Microsoft SQLServerAgent 8.00.2039 版(内部版本号 x86 unicode retail): 进程 ID 2013-09-20 09:46:12 - ? [100] Microsoft SQLServerAgent 8.00.2039 版(内部版本号 x86 unicode retail): 进程 ID 796 2013-09-20 09:46:12 - ? [101] SQL Server 8.00.2039 版(0 连接限制) 2013-09-20 09:46:12 - ? [102] SQL Server ODBC 驱动程序 3.85.1117 版 2013-09-20 09:46:12 - ? [103] 正由驱动程序使用的 NetLib 是 DBMSSHRN.DLL;本地主机服务器是 2013-09-20 09:46:12 - ? [310] 检测到 2 个处理器和 2048 MB RAM 2013-09-20 09:46:12 - ? [339] 本地计算机是 GETHRTESTW2KS,运行 Windows NT 5.0 (2195) Service Pack 4 2013-09-20 09:46:12 - ! [000] SQLServerAgent 必须可以以 SysAdmin 身份连接到 SQLServer,但是“(未知)”不是 SysAdmin 角色的成员 2013-09-20 09:46:13 - ? [098] SQLServerAgent 已终止 (正常)
看来是权限问题,但是具体原因又不太清除,搜索后终于在这位老兄的博客http://www.sqldbadiaries.com/2011/01/17/sql-server-agent-does-not-start-unknown-is-not-a-member-of-the-sysadmin-role/找到答案,生产环境是用一个NT账号(域账号)启动该服务,
但是在测试环境使用本地系统账号(Local System)
但是由于BUILTINAdministrators这个登录名没有sysadmin服务器角色,所以启动上面的SQL SERVER代理服务时,就报那个错误了。只需要勾选上sysadmin角色,然后重启该服务就OK了