SqlServer服務無法啟動的處理方法
SqlServer服務無法啟動,應該如何解決呢?下面就教您一個SqlServer服務無法啟動的處理方法,如果您也遇到過類似的問題,不妨一看。
我們知道SQL Server中最重要的一個數據庫是master數據庫,這個系統數據庫如果有損壞的話,毫無疑問服務器就將不能正常地提供服務。
在某些時候,master數據庫確實受到損壞,無法通過正常的方式登陸了,那么管理員應該怎么樣去想辦法對其進行還原操作呢?
在SQL Server的設計中提供了所謂的單用戶模式(或者也稱為管理模式),通常在危急關頭,我們會以這種模式來啟動SQL Server,并對master數據庫進行還原操作
在SQL Server 2000的時候,我們可以通過下列命令行的方式啟動單用戶模式(SQL Server的服務必須先停止)
sqlservr -m
這時會以管理員模式啟動SQL Server的主服務,你也可以看到如下面這樣的一些輸出,實際上這也是每次SQL Server服務啟動時所做的一些事情
2007-03-08 18:22:03.46 server Microsoft SQL Server 2000 - 8.00.2039 (Intel X86)
May 3 2005 23:18:38
Copyright (c) 1988-2003 Microsoft Corporation
Developer Edition on Windows NT 5.1 (Build 2600: Service Pack 2)
2007-03-08 18:22:03.46 server Copyright (C) 1988-2002 Microsoft Corporation.
2007-03-08 18:22:03.46 server 保留所有權利。
2007-03-08 18:22:03.46 server 服務器進程 ID 是 2976。
2007-03-08 18:22:03.46 server 將 SQL Server 消息記錄在文件“C:\Program Files\Microsoft SQL Server\MSSQL\log\ERRORLOG”中。
2007-03-08 18:22:03.48 server SQL Server 正在以優先級“normal”(已檢測到 1 CPU)啟動。
2007-03-08 18:22:03.50 server 已為 thread 模式處理而配置了 SQL Server。
2007-03-08 18:22:03.51 server 使用 dynamic 鎖分配。[2500] 鎖塊,[5000] 鎖所有者塊。
2007-03-08 18:22:03.52 server 嘗試初始化分布式事務處理協調器。
2007-03-08 18:22:03.55 server Failed to obtain TransactionDispenserInterface: XACT_E_TMNOTAVAILABLE
2007-03-08 18:22:03.56 spid3 警告 ******************
2007-03-08 18:22:03.56 spid3 SQL Server 以單用戶模式啟動。允許對系統目錄進行更新。
2007-03-08 18:22:03.56 spid3 啟動數據庫“master”。
2007-03-08 18:22:04.38 spid3 0 個事務在數據庫“master”中后滾 (1)。
2007-03-08 18:22:04.38 spid3 恢復操作正在對數據庫 'master'(1)執行檢查點操作。
2007-03-08 18:22:04.51 server 正在使用“SSNETLIB.DLL”版本“8.0.2039”。
2007-03-08 18:22:04.52 spid5 啟動數據庫“model”。
2007-03-08 18:22:04.53 server SQL Server 正在監聽 169.254.10.189: 1433。
2007-03-08 18:22:04.53 server SQL Server 正在監聽 127.0.0.1: 1433。
2007-03-08 18:22:04.53 server SQL Server 正在監聽 TCP, Shared Memory, Named Pipes。
2007-03-08 18:22:04.53 server SQL Server 已準備好進行客戶端連接
2007-03-08 18:22:04.56 spid3 服務器名稱是“THINKER-XP”。
2007-03-08 18:22:04.56 spid7 啟動數據庫“msdb”。
2007-03-08 18:22:04.56 spid8 啟動數據庫“pubs”。
2007-03-08 18:22:04.56 spid9 啟動數據庫“Northwind”。
2007-03-08 18:22:04.56 spid10 啟動數據庫“ReportServer”。
2007-03-08 18:22:05.71 spid8 啟動數據庫“ReportServerTempDB”。
2007-03-08 18:22:05.73 spid5 清除 tempdb 數據庫。
2007-03-08 18:22:05.84 spid9 啟動數據庫“AdventureWorks2000”。
2007-03-08 18:22:05.87 spid10 啟動數據庫“demo”。
2007-03-08 18:22:06.32 spid7 啟動數據庫“ClassNorthwind”。
2007-03-08 18:22:06.69 spid8 啟動數據庫“demo2”。
2007-03-08 18:22:10.89 spid5 啟動數據庫“tempdb”。
2007-03-08 18:22:11.12 spid3 恢復完成。
2007-03-08 18:22:11.12 spid3 SQL global counter collection task is created.
這時候你可以再登陸到企業管理器,對master數據庫進行還原
如果這種方式還是無法修復錯誤的話呢,我們該怎么辦?
當服務器出現無法修復的錯誤,最后的一個手段是重建系統數據庫,然后全部重新附加或者還原用戶數據庫。
重建系統數據庫的方法是運行下面這個工具
C:\Program Files\Microsoft SQL Server\80\Tools\Binn\Rebuildm.exe
SQL Server 2005的時候,要進入單用戶模式的命令行工具是
sqlcmd -A
或者登陸Management Studio的時候,服務器名字前面加上 "Admin:",并且以sa和密碼登陸
【編輯推薦】