我已经运行以下 Powershell 脚本作为 Octopus Deploy 的一部分。
但是,我只希望他们在尚未安装的情况下安装。
我安装了它们,最好也只在它们低于某个版本时安装它们。
有人可以建议什么被认为是最好的方法吗?
Install-PackageProvider -Name NuGet -MinimumVersion 2.8.5.201 -Confirm:$False -Force
Install-Module -Name SqlServer -AllowClobber -Confirm:$False -Force
这样的事情应该有效:
if (Get-Module -ListAvailable -Name SqlServer) {
Write-Host "SQL Already Installed"
}
else {
try {
Install-Module -Name SqlServer -AllowClobber -Confirm:$False -Force
}
catch [Exception] {
$_.message
exit
}
}
if ((Get-PackageProvider -Name NuGet).version -lt 2.8.5.201 ) {
try {
Install-PackageProvider -Name NuGet -MinimumVersion 2.8.5.201 -Confirm:$False -Force
}
catch [Exception]{
$_.message
exit
}
}
else {
Write-Host "Version of NuGet installed = " (Get-PackageProvider -Name NuGet).version
}
最近 MS 将 Package Provider 安装更新为动态。 这允许一个班轮对 nuGet 的各种状态进行操作以安装/更新/确认最新版本: 示例3:动态获取包提供者
Get-PackageProvider -Name "nuGet" -ForceBootstrap |
Select-Object -Property Name, Version |
Format-Table -Autosize
这种方式不需要 if/else,也不需要知道现有/存储库版本。
这是我在各种包/模块案例脚本中测试过的:
# array of modules to install (update) / variables
Clear-Host
$ErrorActionPreference = "SilentlyContinue"
# $debugPreference = "Continue"
$sqlModule = @("PowershellGet", "sqlserver", "dbaTools", "testFalse")
# Dynamically check/install/update Package Provider
Get-PackageProvider -Name "nuGet" -ForceBootstrap |
Select-Object -Property Name, Version |
Format-Table -Autosize
# Force install/update modules from PS Repositry
$sqlModule.ForEach( {if (-not (Get-Module -Name $_ -ListAvailable) ){
Install-Module -Name $_ -AllowClobber -Confirm:$False -Force
} else {
Update-Module -Name $_ -Force
}
}
)
# disable "dbtools" imported notification
Set-DbatoolsConfig -Name Import.SqlpsCheck -Value $false -PassThru |
Register-DbatoolsConfig
# Import installed modules
$sqlModule.ForEach( {if(Get-Module -Name $_ -ListAvailable){
Import-Module -Name $_ | Write-Host "Module $($_) imported"
} else {
Write-Host "Module $($_) not imported" -ForegroundColor Red -BackgroundColor White
}
}
)
# List modules
Get-Module -ListAvailable |
Where-Object {
$_.Name -match $sqlModule[0] -or
$_.Name -match $sqlModule[1] -or
$_.Name -match $sqlModule[2] } |
Select-Object -Property Name, Version |
Format-Table -AutoSize