一部のデータベースを移動(復元、削除など)した後、新しいデータベースの作成で問題が発生しました。具体的には、新しいデータベースMSSQLサーバーを作成しようとすると、「データベース 'モデル'はRESTORINGとマークされており、リカバリを実行できない状態になっている」ために失敗しました。いくつかのオンラインソリューションが示唆するように、MSSQLサービスを開始および停止しようとしました。 「tempdbを作成できませんでした。十分なディスク領域がない可能性があります。tempdbドライブ上の他のファイルを削除して、追加のディスク領域を解放してください」(FYI:ドライブには100 GBの空き領域があります)。 MSSQL Serverが実行されているマシンを再起動してみました。サーバーがオンラインに戻ったときに、同じエラーを受け取りました。 tempdb.mdfを削除して、templatesフォルダーからmodeldbを復元しようとしましたが、どちらも問題を解決しませんでした。シングルユーザーモードでも、データベースに接続できません。多くのオンラインソリューションでは、サーバーに対してSQLコマンドを実行していますが、サーバーにコマンドを実行するために(シングルユーザーモードであっても)DBに接続できません。
特定のエラーメッセージ:
データベース「モデル」を開くことができません。復元の途中です。 (Microsoft SQL Server、エラー:927)
SQL Server(MSSQLSERVER)サービスを開始しています。 SQL Server(MSSQLSERVER)サービスを開始できませんでした。
サービス固有のエラーが発生しました:1814。
できるだけ早くサーバーを稼働させる必要があります。
これは実際にはしばらく前(12年7月)にMicrosoftからの有料サポートコールで修正されました。
これは非常に多くの意見を得ているので、マイクロソフトとの通話の「電子メールの要約」を編集したバージョンを追加することにしました。
投稿はペーストビンへのリンクです: http://Pastebin.com/QqNz7xYd
この情報がこの問題のある人に役立つことを願っています
Problem Description:
=============================
You Microsoft SQL Server 2008 R2 (RTM) - 10.50.1600.1 (X64) default instance on SERVERNAME server and you were trying to start the SQL SERVER service which was failing to start.
Analysis\Troubleshooting:
=============================
We checked the SQLS SERVER ERRORLOG
===========================
2012-06-20 19:33:41.48 Server Microsoft SQL Server 2008 R2 (RTM) - 10.50.1600.1 (X64)
Apr 2 2010 15:48:46
Copyright (c) Microsoft Corporation
Enterprise Edition (64-bit) on Windows NT 6.0 <X64> (Build 6001: Service Pack 1)
2012-06-20 19:33:41.50 Server (c) Microsoft Corporation.
2012-06-20 19:33:41.50 Server All rights reserved.
2012-06-20 19:33:41.50 Server Server process ID is 2596.
2012-06-20 19:33:41.51 Server System Manufacturer: 'HP', System Model: 'ProLiant DL360 G5'.
2012-06-20 19:33:41.51 Server Authentication mode is MIXED.
2012-06-20 19:33:41.51 Server Logging SQL Server messages in file 'D:\Mssql\Data\MSSQL10_50.MSSQLSERVER\MSSQL\Log\ERRORLOG'.
2012-06-20 19:33:41.51 Server This instance of SQL Server last reported using a process ID of 2816 at 6/20/2012 6:10:15 PM (local) 6/20/2012 10:10:15 PM (UTC). This is an informational message only; no user action is required.
2012-06-20 19:33:41.51 Server Registry startup parameters:
-d D:\Mssql\Data\MSSQL10_50.MSSQLSERVER\MSSQL\DATA\master.mdf
-e D:\Mssql\Data\MSSQL10_50.MSSQLSERVER\MSSQL\Log\ERRORLOG
-l D:\Mssql\Data\MSSQL10_50.MSSQLSERVER\MSSQL\DATA\mastlog.ldf
2012-06-20 19:33:41.56 Server SQL Server is starting at normal priority base (=7). This is an informational message only. No user action is required.
2012-06-20 19:33:41.56 Server Detected 4 CPUs. This is an informational message; no user action is required.
2012-06-20 19:33:41.65 Server Using locked pages for buffer pool.
2012-06-20 19:33:41.88 Server Using dynamic lock allocation. Initial allocation of 2500 Lock blocks and 5000 Lock Owner blocks per node. This is an informational message only. No user action is required.
2012-06-20 19:33:42.33 Server Node configuration: node 0: CPU mask: 0x000000000000000f:0 Active CPU mask: 0x000000000000000f:0. This message provides a description of the NUMA configuration for this computer. This is an informational message only. No user action is required.
2012-06-20 19:33:42.49 spid7s Starting up database 'master'.
2012-06-20 19:33:42.86 spid7s Resource governor reconfiguration succeeded.
2012-06-20 19:33:42.86 spid7s SQL Server Audit is starting the audits. This is an informational message. No user action is required.
2012-06-20 19:33:42.87 spid7s SQL Server Audit has started the audits. This is an informational message. No user action is required.
2012-06-20 19:33:42.87 spid7s FILESTREAM: effective level = 0, configured level = 0, file system access share name = 'MSSQLSERVER'.
2012-06-20 19:33:43.02 spid7s SQL Trace ID 1 was started by login "sa".
2012-06-20 19:33:43.03 spid7s Starting up database 'mssqlsystemresource'.
2012-06-20 19:33:43.05 spid7s The resource database build version is 10.50.1600. This is an informational message only. No user action is required.
2012-06-20 19:33:43.24 spid10s Starting up database 'model'.
2012-06-20 19:33:43.24 spid7s Server name is 'SERVERNAME'. This is an informational message only. No user action is required.
2012-06-20 19:33:43.27 spid10s The database 'model' is marked RESTORING and is in a state that does not allow recovery to be run.
2012-06-20 19:33:43.28 spid10s Error: 927, Severity: 14, State: 2.
2012-06-20 19:33:43.28 spid10s Database 'model' cannot be opened. It is in the middle of a restore.
2012-06-20 19:33:43.36 spid10s Could not create tempdb. You may not have enough disk space available. Free additional disk space by deleting other files on the tempdb drive and then restart SQL Server. Check for additional errors in the event log that may indicate why the tempdb files could not be initialized.
2012-06-20 19:33:43.36 spid10s SQL Trace was stopped due to server shutdown. Trace ID = '1'. This is an informational message only; no user action is required.
===========================
From ERRORLOG we can see that SQL SERVER trying to bring model database online but since model database in recovery state hence we were unable to run database recovery.
We also know that whenever SQL SERVER start we recreate TEMPDB database by coping the content from model database.
Now since model database didn’t started hence TEMPDB startup also failed which is one of critical system database and this caused SQL SERVER service to failed
Solution:
=====================================
· To fix this issue we started SQL SERVER EXE with following parameter from command Prompt
SQLSERVR.EXE -c -T3608
· Then after we detached model database using following T-SQL
sp_detach_db model
· Then after we attach the model database using following T-SQL
================================
USE MASTER
GO
CREATE DATABASE MODEL
ON (FILENAME = 'C:\PROGRAM FILES\Microsoft SQL SERVER\MSSQL10_50.MSSQLSERVER\MSSQL\DATA\MODEL.MDF')
FOR ATTACH ;
================================
· After that SQL SERVER service came online successfully
自動回復をバイパスしてSQLサービスを開始できますか?
net start mssqlserver /f /m /t3608
その後、モデルを復元してみますか?
sqlcmd -e
restore database
model go
編集:見つかった このリンク も同様に、より詳細になり、おそらくより正確になります。