適用対象: ✔️ Windows VM
この記事では、VM がセーフ モードで起動するように構成されているために Azure Windows 仮想マシン (VM) に接続できない問題を解決する方法を示します。
現象
VM がセーフ モードで起動するように構成されているため、Azure 上の VM への RDP 接続またはその他の接続 (HTTP など) を行うことができません。 Azure portal 上でブート診断のスクリーンショットを確認すると、VM は正常に起動しているがネットワーク インターフェイスが使用可能でないことがわかる場合があります。
原因
RDP サービスは、セーフ モードでは使用できません。 VM がセーフ モードで起動するときは、基本的なシステム プログラムとサービスだけが読み込まれます。 これは、"最低限のセーフ ブート" および "接続のあるセーフ ブート" という 2 つの異なるバージョンのセーフ モードに適用されます。
ソリューション
これらの手順を実行する前に、バックアップとして、影響を受ける VM の OS ディスクのスナップショットを取得します。 詳細については、ディスクのスナップショットに関する記事を参照してください。
この問題を解決するには、シリアル コントロールを使用して通常モードで起動するように VM を構成するか、または復旧 VM を使用して VM をオフライン修復します。
シリアル コントロールを使用する
シリアル コンソールに接続し、CMD インスタンスを開きます。 VM 上でシリアル コンソールが有効になっていない場合は、「VM をオフライン修復する」をご覧ください。
ブート構成データを確認します。
bcdedit /enumVM がセーフ モードで起動するように構成されている場合、 [Windows ブート ローダー] セクションに [safeboot] という追加のフラグが表示されます。 [safeboot] フラグが表示されない場合、VM はセーフ モードではありません。 そのシナリオには、この記事の内容は当てはまりません。
[safeboot] フラグは、次の値と共に表示されることがあります。
最小
ネットワーク
この 2 つのモードのいずれでも、RDP は開始されません。 そのため、修正プログラムは同じままです。
[safemoade] フラグを削除すると、VM が通常モードで起動します。
bcdedit /deletevalue {current} safebootブート構成データをチェックして、 [safeboot] フラグが削除されていることを確認します。
bcdedit /enumVM を再起動し、問題が解決されているかどうかを確認します。
VM をオフライン修復する
復旧 VM に OS ディスクを接続する
- 復旧 VM に OS ディスクを接続します。
- 復旧 VM へのリモート デスクトップ接続を開始します。
- ディスクが [ディスクの管理] コンソールで [オンライン] になっていることを確認します。 接続された OS ディスクに割り当てられたドライブ文字をメモします。
ダンプ ログとシリアル コンソールを有効にする (省略可能)
ダンプ ログとシリアル コンソールは、この記事の解決策では問題を解決できない場合にさらにトラブルシューティングを行うのに役立ちます。
ダンプ ログとシリアル コンソールを有効にするには、次のスクリプトを実行します。
管理者特権のコマンド プロンプト セッション ( [管理者として実行] ) を開きます。
次のスクリプトを実行します。
このスクリプトでは、接続されている OS ディスクに割り当てられているドライブ文字が F であると想定しています。このドライブ文字を実際の VM の適切な値に置き換えてください。
reg load HKLM\BROKENSYSTEM F:\windows\system32\config\SYSTEM REM Enable Serial Console bcdedit /store F:\boot\bcd /set {bootmgr} displaybootmenu yes bcdedit /store F:\boot\bcd /set {bootmgr} timeout 5 bcdedit /store F:\boot\bcd /set {bootmgr} bootems yes bcdedit /store F:\boot\bcd /ems {<BOOT LOADER IDENTIFIER>} ON bcdedit /store F:\boot\bcd /emssettings EMSPORT:1 EMSBAUDRATE:115200 REM Suggested configuration to enable OS Dump REG ADD "HKLM\BROKENSYSTEM\ControlSet001\Control\CrashControl" /v CrashDumpEnabled /t REG_DWORD /d 1 /f REG ADD "HKLM\BROKENSYSTEM\ControlSet001\Control\CrashControl" /v DumpFile /t REG_EXPAND_SZ /d "%SystemRoot%\MEMORY.DMP" /f REG ADD "HKLM\BROKENSYSTEM\ControlSet001\Control\CrashControl" /v NMICrashDump /t REG_DWORD /d 1 /f REG ADD "HKLM\BROKENSYSTEM\ControlSet002\Control\CrashControl" /v CrashDumpEnabled /t REG_DWORD /d 1 /f REG ADD "HKLM\BROKENSYSTEM\ControlSet002\Control\CrashControl" /v DumpFile /t REG_EXPAND_SZ /d "%SystemRoot%\MEMORY.DMP" /f REG ADD "HKLM\BROKENSYSTEM\ControlSet002\Control\CrashControl" /v NMICrashDump /t REG_DWORD /d 1 /f reg unload HKLM\BROKENSYSTEM
通常モードで起動するように Windows を構成する
管理者特権のコマンド プロンプト セッション ( [管理者として実行] ) を開きます。
ブート構成データを確認します。 次のコマンドでは、接続されている OS ディスクに割り当てられているドライブ文字が F であると想定しています。このドライブ文字を実際の VM の適切な値で置き換えてください。
bcdedit /store F:\boot\bcd /enum\windows フォルダーが含まれるパーティションの識別子名をメモしておきます。 既定では、識別子名は "Default" です。
VM がセーフ モードで起動するように構成されている場合、 [Windows ブート ローダー] セクションに [safeboot] という追加のフラグが表示されます。 safeboot フラグが表示されない場合、この記事の内容は目的のシナリオに当てはまりません。
safeboot フラグを削除すると、VM が通常モードで起動します。
bcdedit /store F:\boot\bcd /deletevalue {Default} safebootブート構成データをチェックして、 [safeboot] フラグが削除されていることを確認します。
bcdedit /store F:\boot\bcd /enumOS ディスクを切断して、VM を再作成します。 その後、問題が解決されているかどうかを確認します。
お問い合わせはこちらから
質問がある場合やヘルプが必要な場合は、サポート要求を作成するか、Azure コミュニティ サポートにお問い合わせください。 Azure フィードバック コミュニティに製品フィードバックを送信することもできます。