Деплой образов
Распаковка нужного install.wim из install.esd
Иногда (например, при скачивании образа при помощи Media Creation Tool) в папке sources нет файла install.wim, который нужен для создания образа в MECM, а есть только файл install.esd. Данный файл представляет собой зашифрованный архив, содержащий все доступные системы, собранные в конкретном ISO-образе. В этом случае мы сначала можем посмотреть его содержимое.
Для просмотра выполним команду:
dism /Get-WimInfo /WimFile:"E:\custom_distr\Win 10 Enterprise\sources\install.esd"
Теперь ищем и запоминаем нужный ID, после чего выполняем команду, которая разархивирует нужный образ:
dism /Export-Image /SourceImageFile:"E:\custom_distr\Win 10 Enterprise\sources\install.esd" /SourceIndex:2 /DestinationImageFile:"E:\custom_distr\Win 10 Enterprise\sources\install.wim" /Compress:max /CheckIntegrity
Автоматический выбор быстрого диска для установки
Проблема: по умолчанию task sequence в MECM выбирает для установки диск с номером 0. Но что, если диск с номером 0 - HDD, в то время, как быстрый диск SSD (или NVMe) в компьютере имеет другой номер? В этом случае система будет установлена на HDD.
Чтобы этого избежать, в task sequence нужно встроить powershell скрипт, который находит SSD или NVME диск и устанавливает систему именно туда.
1. Перед тем, как вставлять скрипт PS в task sequence - нужно убедиться, что наш boot image поддерживает powershell, а также нужные PS-модули. Если нет - их обязательно нужно добавить. Список необходимых модулей показан на скриншоте.
2. После добавления модулей, в task sequence - добавляем запуск PS-скрипта, сразу за этапом “Restart in Windows PE”.
В параметрах запуска PS-скрипта нужно обязательно поменять execution policy на “bypass”, иначе скрипт не запустится.
Ниже приведен сам скрипт. Он сохраняет результат выбора диска в переменную OSDDiskIndex, которую мы будем использовать на дальнейших шагах.
#defalt value $disk_idx = 0 #retrieve SSD $ssd_disk = get-physicaldisk | where mediatype -like 'ssd' #multiple SSD if (@($ssd_disk).count -gt 1) { #multiple nvme SSD, choose the smallest one if (@($ssd_disk | where bustype -like 'nvme').count -gt 1) { $disk_idx = $ssd_disk | Sort-Object -Property Size | Select-Object -ExpandProperty DeviceID -First 1 } elseif (@($ssd_disk | where bustype -like 'nvme').count -eq 1) { $disk_idx = ($ssd_disk | where bustype -like 'nvme').deviceid } } #singel SSD elseif (@($ssd_disk).count -eq 1) { #multiple physical disks, choose SSD if (@(get-physicaldisk).count -gt 1) { $disk_idx = ($ssd_disk).deviceid } #single pysical disks else { $disk_idx = 0 } } #Write-Host "disk selected: $disk_idx" (New-Object -COMObject Microsoft.SMS.TSEnvironment).Value('OSDDiskIndex') = $disk_idx
3. Теперь на ОБОИХ (BIOS и UEFI) этапах “partition disk 0” - указываем вместо статического номера диска - переменную OSDDiskIndex, значение которой будет установлено PS-скриптом, который мы настроили.
Теперь, при запуске, образ будет искать оптимальный диск для установки системы.