如果尚未安装,则只安装 PowerShell PackageProvider 和 Module

问题描述 投票:0回答:2

我已经运行以下 Powershell 脚本作为 Octopus Deploy 的一部分。

但是,我只希望他们在尚未安装的情况下安装。

我安装了它们,最好也只在它们低于某个版本时安装它们。

有人可以建议什么被认为是最好的方法吗?

Install-PackageProvider -Name NuGet -MinimumVersion 2.8.5.201 -Confirm:$False -Force 

Install-Module -Name SqlServer -AllowClobber -Confirm:$False -Force  
sql-server powershell octopus-deploy
2个回答
17
投票

这样的事情应该有效:

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
}

0
投票

最近 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
© www.soinside.com 2019 - 2024. All rights reserved.