LoginSignup
19
32

More than 5 years have passed since last update.

Hyper-Vチェックポイントが膨れ上がり、ディスク枯渇したときの復旧方法

Posted at

環境

  • Hyper-V Server 2012 R2

ディスク枯渇は突然に

ある日、社内で使っているHyper-V Server上の仮想マシンが全て「一時停止」状態になりました。
見てみると、ホストOSのディスク使用量が0%になっていました。

え?全然心当たりないし。

と思ったものの、念の為調べて見ると、チェックポイント(VMwareでいうところのスナップショットみたいなもの)の容量がとんでもないことになっていました。

ピンときました。
1ヶ月前に仮想マシンをメンテナンスする際に、チェックポイント作成してそのまま削除せずに今に至っていました。

そして長い復旧が始まった・・・

幸いにも自分たちが社内で使ってる検証用の仮想マシンたちなので、影響はあまりないものの、インフラエンジニアとしては可及的速やかに復旧したいところです。

チェックポイント削除

image.png

はい。これが失敗の始まりでした。
軽い気持ちで削除しちゃえばよくね?と思ってやっちゃいましたが、よくよく考えるとチェックポイントを結合する為の容量が不足してますね。

当然失敗します。

ここで、きちんとスナップショット容量分のディスクを確保して削除すれば無事復旧です。
でも、それを怠った私はここから長い復旧作業に陥ることになります。

チェックポイントに不整合が?

さて、チェックポイントの削除に失敗しましたが、Hyper-Vマネージャから見るとチェックポイントは存在しないことになってます。

image.png

でも、仮想ディスク格納先フォルダを見てみると、チェックポイントファイル(.avhdx)はしっかり残っています。
不整合ですね。
ちょっと危険な香りがしてきました。

とりあえずディスク容量確保!

過去作ったけどもはやいらない仮想ディスクなんかを削除しまくって、スナップショット容量と同程度の空きを作りました。

手動でチェックポイントを結合する

  • Hyper-Vマネージャから、[編集]→[ディスクの編集]を選択します。
  • ディスクの編集ウィザードが開くので、[次へ]を選択します。
  • [参照]を選択します。
    image.png

  • 対象のチェックポイントファイルを選択します。チェックポイントが複数ある場合は、1番新しいものを選択してください。
    image.png

  • [結合]を選択します。
    image.png

  • [親ハードディスクに結合する]を選択します。
    image.png

  • 対象のチェックポイントと親が正しいことを確認して[完了]を選択します。
    image.png

  • 結合失敗する場合は、仮想マシンを停止して試してみてください。私はそれでうまくいきました。(てか、この作業やる前に停止したほうがよかった・・・)

  • この処理をスナップショットがなくなるまで繰り返します。結合は新しいスナップショットから順々に実施していきます。

いざ仮想マシン起動!・・・あれ?

  • 仮想マシンのハードディスクの向き先がチェックポイントファイルになっているので、これを本体のvhdxファイルに変更します。
  • 仮想マシンを[右クリック]→[設定]→[SCSIコントローラー]→[ハードドライブ]→[参照]を選択して、vhdxファイルに変えてあげます。
    image.png

  • さて準備は整った。いざ適用!・・・データ損失?なんだか怖いメッセージが出ますが、ここは勇気を出して[続行]を押します。
    image.png

  • さあ、いざ適用!
    image.png

ハードドライブの変更を適用中にエラーが発生しました
ディスクを変更できません。ディスク結合が保留中です。

ゾッとしました。
この時点でマズイかなと思い始めました。対策が思い浮かばない・・・
頭の中では利用者のみんなになんて謝ろうか駆け巡ってました

とりあえずHyper-V Server自体を再起動してみる

困ったときの再起動
Hyper-Vがなんか掴んでて再起動したら結合の保留も終わるんじゃね?という安易な考えです。

再起動しても症状は変わりませんでした。

仮想ハードディスクの画面で、「この仮想マシンにはチェックポイントがあるため、[編集]は使用できません」と出ています。
image.png

これをどうにかしないといけないのでは??

仮想ディスクを切断する

これが正解でした。
チェックポイントの仮想ディスクを切断して、本体ディスクを追加するというやり方です。

  • 仮想マシンを[右クリック]→[設定]→[SCSIコントローラー]→[ハードドライブ]を選択して、[削除]を押します。
    image.png
    削除って名前が怖いですよね・・・切断とかにすればいいのに。
    これ適用しても仮想ディスクは消えないので安心してください。

  • [適用]を押します
    image.png

  • もはや見慣れたデータ損失のメッセージ。[続行]を押します。
    image.png

  • 仮想ディスクが消えました。
    image.png

  • 次に本体の.vhdxファイルを接続します。SCSIコントローラーからハードドライブを追加します。
    image.png

  • [参照]を選択して、.vhdxファイルを選択します。
    image.png

  • いざ、適用!
    お!エラー出ない!

仮想マシンを起動してみると無事立ち上がりました!!

めちゃめちゃ焦りましたが、無事復旧することができました。
チェックポイントの消し忘れには注意しましょう!

19
32
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
19
32