SQLSERVER启动不起来(错误9003)的解决方法分享
先说一下环境客户环境:Windows2003企业版SP2 32位 SQL2005企业版 32位 SP4 客户那边的master数据库大小:几MB 检查 先打开SQLSERVER配置管理器,启动SQLSERVER,发现SQLSERVER启动不起来 于是我打开Windows EventLog,发现了下面错误 代码如下:SQLSERVER 错误9003:LSN无效(日志扫描号无效) 于是我就在自己的电脑上百度了一下这个错误 想办法 由下面几个因素,我作出了一个选择 选择:以前项目经理教我的一个方法,遇到SQLSERVER启动不起来 这种方法有下面的弊端 (1)你所用的数据库版本一定要和客户的一样 为什麽会有这些弊端,大家可以看一下下面的文章 代码如下:【SERVICE SID的引入】 因为登录用户的机制在SQLSERVER2008的时候发生了变化,所以你所用的数据库版本不和客户的一样是不行的 开始实施 弊端说完了,开始实施了 第一步:先把我自己笔记本电脑上的SQLSERVERD 所有用户数据库全部分离, 删除一些安装时候没有的登录用户只保留默认的登录用户,停止自己电脑的SQL服务,然后把master.mdf和mastlog.ldf复制出来,发给客户 第二步:使用远程协助,把客户电脑里的master数据库master.mdf文件改名为master22.mdf mastlog.ldf文件改名为mastlog22.ldf 然后把发过来的master数据库放进去data文件夹里 第三步:启动SQLSERVER,由于当时没有截图,这里就不放截图了,这时候可以发现SQLSERVER成功启动了 第四步:把我们的业务库重新附加进来 第五步:删除原来业务库里的那个数据库用户gxhtsyrain 第六步:新建登录用户gxhtsyrain并且映射到我们的业务库 第七步:禁用sa用户 由于不是替换msdb数据库,所以维护计划没有丢失
我查看SQL ERRORLOG,发现了下面的错误 无法启用数据库 "msdb" 中的 Service Broker,因为master与msdb 的 Service Broker 的ID不一样 NT AUTHORITYSYSTEM登录失败 由于我们没有用到 Service Broker技术,所以“无法启用数据库 "msdb" 中的 Service Broker”这个错误可以忽略 而NT AUTHORITYSYSTEM登录失败,在文章SQL Server 2008中的Service SID 介绍中说到 代码如下:但是我们也不能认为有这几个SID的帐号,就能随便把其他的登录如NT AUTHORITYSYSTEM给删除。 某些应用,如VSS Writer,Windows自动更新等,还是需要用服务启动帐号来进行处理。 如果客户那边有做SQLSERVER的系统数据库备份 我会这样做: 第一步:先备份我自己笔记本电脑里的master数据库出来 第二步:将客户那边的master.bak拿到自己的电脑里 第三步:还原客户的master.bak到自己的SQLSERVER 第四步:停止SQL服务,然后把master.mdf和mastlog.ldf复制出来发送给客户 第五步:把客户电脑里的master数据库master.mdf文件改名为master22.mdf,mastlog.ldf文件改名为mastlog22.ldf 第六步:然后把发过来的master数据库放进去data文件夹里 第七步:启动SQLSERVER 总结 其实除了备份用户数据库之外,系统数据库的备份也是很重要的 (编辑:李大同) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |