В этой статье хочу рассказать, как можно убрать из консоли VMM сведения о некорректно удаленных серверах. Например, в моем случае с одного из бывших серверов виртуализации сняли роль Hyper-V, поставили чистую ОС и отдали под другие задачи, а из консоли VMM отключить забыли. В результате чего при попытке удаления штатными средствами получилось вот так:

image

Собственно, теперь с этим сервером сделать ничего нельзя ни из GUI, ни из PowerShell. Результат будет примерно такой:

image

Так как все данные о серверах кластерах и прочих виртуальных машинах VMM хранит в базе MS SQL, то ее мы и будем очищать от записей об этом узле. Предварительно стоит сделать бэкап базы VMM.

Для этого нам понадобится Sql Management Studio. Запустив который подключимся к базе VMM и найдем идентификатор нужного нам хоста, выполнив запрос:

use VirtualManagerDB
 select HostID, computerName from dbo.tbl_ADHC_Host 


Если сразу попробуем удалить запись о хосте:

use VirtualManagerDB
 delete from dbo.tbl_ADHC_Host where HostID like 'hostid' 


То получим только сообщение о ошибке из-за зависимостей. Для успешного удаления этой записи нам необходимо сперва удалить все, что связано с определенным нами HostID в следующих таблицах:

dbo.tbl_NetMan_InstalledVirtualSwitchExtension

dbo.tbl_ADHC_HostBusAdapter

dbo.tbl_ADHC_VirtualNetwork

dbo.tbl_ADHC_HostVolume

dbo.tbl_ADHC_HostDisk


dbo.tbl_ADHC_HostBusAdapter — при удалении записи из этой таблицы у меня появилась ошибка ссылающаяся на dbo.tbl_ADHC_HostInternetSCSIHba.

В таблице dbo.tbl_ADHC_HostInternetSCSIHba нету HostID и поэтому придется вывести все записи из нее чтобы определить id нужного нам ISCSIHbaID

use VirtualManagerDB
select * from dbo.tbl_ADHC_HostInternetSCSIHba


И после этого удаляем запись:

use VirtualManagerDB
 delete from dbo.tbl_ADHC_HostInternetSCSIHba like 'ISCIHbaID' 


Теперь удаление записи из таблицы dbo.tbl_ADHC_HostBusAdapter пройдет успешно.

В завершении выполняем удаление записи из таблицы хостов:

use VirtualManagerDB
delete from dbo.tbl_ADHC_Host where HostID like 'hostid' 


Теперь, перезапустив консоль VMM, мы увидим, что «зависшего» сервера там уже нет.

image

Комментарии (6)


  1. Eklykti
    14.07.2015 23:37

    Энтерпрайзненько.


    1. Shaz Автор
      15.07.2015 11:49

      В каком смысле?


      1. Krypt
        15.07.2015 18:07
        +1

        Удаление гланд через зад ;)


        1. Shaz Автор
          15.07.2015 18:37

          Ну просто не оставили выбора. И это еще на самый страшный случай.


          1. Krypt
            15.07.2015 18:44
            +1

            За корпоративными продуктами замечена такая деталь: они почему-то считают, что владеют ками-нибудь ресурсами безраздельно и эксклюзивно, хотя на самом деле это не так. В результате и приходится шаманить.


  1. Shaz Автор
    15.07.2015 19:50

    Ну в моем случае ресурсы без проблем были отданы под другие цели. Вот только VMM никто об это не уведомил, и как результат:

    Удаление гланд через зад ;)