"invoke-command" с использованием wusa.exe в powershell - не устанавливает msu
Я пытаюсь установить исправление Windows на несколько компьютеров в нашей сети, используя PowerShell v3. Я скачал соответствующий .msu
файл, я смог успешно установить его с локальной машины в командной строке, используя:
wusa c:\temp\hotfixname.msu /quiet /norestart
Проблема возникает, когда я пытаюсь запустить его из powershell. Можно предположить, что msu уже есть у всех на c:\temp\hotfixname.msu
и что PSRemoting уже включен. Вот что у меня более или менее:
import-module ActiveDirectory
$AllPCs = Get-ADComputer -SearchBase "Appropriate OU Here" -filter *
$AllPCs | Foreach {
Invoke-Command -ComputerName "$($_.name)" -AsJob -ScriptBlock {
if (!(Get-HotFix -id hotfixkb)) { CMD /C "wusa.exe c:\temp\hotfixname.msu /quiet /norestart" }
}
}
Когда я запускаю это из моего собственного окна администратора, запуская powershell от имени администратора, локальный компьютер открывает wusa.exe
Процесс в течение секунды или около того, прежде чем он исчезнет. Ничего не установлено.
я могу бежать CMD /C "wusa.exe /?
и он открывает процесс (зависает, но только потому, что wusa
открывает свою справку в графическом интерфейсе).
У меня нет идей - есть у кого-нибудь совет по этому поводу? Я что-то упускаю?
2 ответа
Поскольку PSRemoting использует WinRM и в соответствии с этим не похоже, что вы можете использовать wusa.exe
с WinRM или WinRS это не представляется возможным с кодом, который вы перечислили.
Однако есть обходной путь:
Извлеките файл MSU через Windows Remote Shell с WUSA, используя следующую команду:
winrs.exe -r:% computername% wusa.exe% kb-update% / extract:% назначение%
По завершении установите пакет.cab с помощью dism.exe или диспетчера пакетов. Чтобы использовать dism.exe, используйте команду ниже:
winrs.exe -r:% computername% dism.exe / online / add-package /PackagePath:%Path_To_Package%\KBnnnnnnn.cab
Удаленное обновление powershell с 3 -> 5.1 (windows7), через интерфейс WinRM и сервер Ansible - скрипт PSH update-psh.ps1 (работал для меня):
# install POWERSHELL update
# descr. wusa: https://support.microsoft.com/en-us/help/934307/description-of-the-windows-update-standalone-installer-in-windows
# descr. dism: https://docs.microsoft.com/en-us/windows-hardware/manufacture/desktop/dism-operating-system-package-servicing-command-line-options
Start-Process -FilePath 'wusa.exe' -ArgumentList "C:\workit\updatePSH\Win7AndW2K8R2-KB3191566-x64.msu /extract:C:\workit\updatePSH" -Verb RunAs -Wait -Passthru
Start-Sleep -Seconds 5
Start-Process -FilePath 'dism.exe' -ArgumentList "/online /add-package /PackagePath:C:\workit\updatePSH\WSUSSCAN.cab /PackagePath:C:\workit\updatePSH\Windows6.1-KB2809215-x64.cab /PackagePath:C:\workit\updatePSH\Windows6.1-KB2872035-x64.cab /PackagePath:C:\workit\updatePSH\Windows6.1-KB2872047-x64.cab /PackagePath:C:\workit\updatePSH\Windows6.1-KB3033929-x64.cab /PackagePath:C:\workit\updatePSH\Windows6.1-KB3191566-x64.cab /IgnoreCheck /quiet" -Verb RunAs -Wait -PassThru