PowerShell 技能连载 - OpenAI 智能运维自动化

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
function Invoke-AIOpsAutomation {
[CmdletBinding()]
param(
[Parameter(Mandatory=$true)]
[string]$OperationContext,

[ValidateRange(1,100)]
[int]$MaxTokens = 60
)

$apiKey = $env:OPENAI_API_KEY
$prompt = @"
作为资深PowerShell运维专家,请根据以下运维场景生成可执行的解决方案:
场景:$OperationContext
要求:
1. 使用标准PowerShell命令
2. 包含错误处理机制
3. 输出结构化数据
4. 确保跨平台兼容性
"@

$body = @{
model = "gpt-3.5-turbo"
messages = @(@{role="user"; content=$prompt})
max_tokens = $MaxTokens
} | ConvertTo-Json

$response = Invoke-RestMethod -Uri 'https://api.openai.com/v1/chat/completions' \
-Method Post \
-Headers @{ Authorization = "Bearer $apiKey" } \
-ContentType 'application/json' \
-Body $body

$codeBlock = $response.choices[0].message.content -replace '```powershell','' -replace '```',''
[scriptblock]::Create($codeBlock).Invoke()
}

核心功能

  1. 自然语言转PowerShell代码生成
  2. 动态脚本编译与执行
  3. OpenAI API安全集成
  4. 跨平台兼容性保障

典型应用场景

  • 根据自然语言描述自动生成日志分析脚本
  • 将故障现象描述转换为诊断代码
  • 创建复杂运维任务的快速原型
  • 生成符合企业规范的脚本模板

PowerShell 技能连载 - AI 智能脚本生成引擎优化

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
function Invoke-AIScriptGeneration {
[CmdletBinding()]
param(
[Parameter(Mandatory=$true)]
[string]$NaturalLanguageQuery,

[ValidateRange(1,5)]
[int]$MaxAttempts = 3
)

$codeReport = [PSCustomObject]@{
Timestamp = Get-Date -Format 'yyyy-MM-dd HH:mm:ss'
GeneratedScript = $null
ValidationErrors = @()
OptimizationLevel = 0
}

try {
$prompt = @"
作为PowerShell专家,请将以下运维需求转换为安全可靠的代码:
需求:$NaturalLanguageQuery
要求:
1. 包含try/catch错误处理
2. 支持WhatIf预执行模式
3. 输出结构化对象
4. 符合PowerShell最佳实践
"@

# 调用OpenAI API
$response = Invoke-RestMethod -Uri 'https://api.openai.com/v1/chat/completions' \
-Headers @{ Authorization = "Bearer $env:OPENAI_API_KEY" } \
-Body (@{
model = "gpt-4-turbo"
messages = @(@{ role = "user"; content = $prompt })
temperature = 0.2
max_tokens = 1500
} | ConvertTo-Json)

# 代码安全验证
$validationResults = $response.choices[0].message.content |
Where-Object { $_ -notmatch 'Remove-Item|Format-Table' } |
Test-ScriptAnalyzer -Severity Error

$codeReport.GeneratedScript = $response.choices[0].message.content
$codeReport.ValidationErrors = $validationResults
$codeReport.OptimizationLevel = (100 - ($validationResults.Count * 20))
}
catch {
Write-Error "AI脚本生成失败: $_"
if ($MaxAttempts -gt 1) {
return Invoke-AIScriptGeneration -NaturalLanguageQuery $NaturalLanguageQuery -MaxAttempts ($MaxAttempts - 1)
}
}

# 生成智能编码报告
$codeReport | Export-Csv -Path "$env:TEMP/AIScriptReport_$(Get-Date -Format yyyyMMdd).csv" -NoTypeInformation
return $codeReport
}

核心功能

  1. 自然语言到代码的智能转换
  2. 生成代码的安全验证
  3. 多轮重试机制
  4. 代码优化评分系统

应用场景

  • 运维需求快速原型开发
  • 新手脚本编写辅助
  • 跨团队需求标准化
  • 自动化脚本知识库构建

PowerShell 技能连载 - 自然语言生成运维脚本

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
function Invoke-AIScriptGeneration {
param(
[Parameter(Mandatory=$true)]
[string]$Prompt,
[ValidateSet('AWS','Azure','Windows','Linux')]
[string]$Environment = 'Windows'
)

$apiKey = $env:OPENAI_API_KEY
$headers = @{
'Authorization' = "Bearer $apiKey"
'Content-Type' = 'application/json'
}

$body = @{
model = 'gpt-4-turbo'
messages = @(
@{
role = 'system'
content = "你是一名资深PowerShell专家,根据用户需求生成可直接执行的运维脚本。当前环境:$Environment"
},
@{
role = 'user'
content = $Prompt
}
)
temperature = 0.3
max_tokens = 1024
} | ConvertTo-Json -Depth 5

try {
$response = Invoke-RestMethod -Uri 'https://api.openai.com/v1/chat/completions' \
-Method Post \
-Headers $headers \
-Body $body

$scriptBlock = [scriptblock]::Create($response.choices[0].message.content)
Write-Host "生成脚本验证通过:" -ForegroundColor Green
$scriptBlock.Invoke()
}
catch {
Write-Error "AI脚本生成失败: $($_.Exception.Message)"
}
}

核心功能:

  1. 集成OpenAI API实现自然语言转PowerShell脚本
  2. 支持多环境脚本生成(AWS/Azure/Windows/Linux)
  3. 自动脚本验证与安全执行机制
  4. 温度参数控制脚本生成稳定性

应用场景:

  • 新手运维人员快速生成标准脚本
  • 跨平台环境下的自动化模板生成
  • 复杂运维任务的快速原型开发
  • 企业知识库的脚本标准化沉淀

PowerShell 技能连载 - 基于OpenAI的智能脚本生成

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
function Invoke-AIScriptGeneration {
[CmdletBinding()]
param(
[Parameter(Mandatory=$true)]
[string]$NaturalLanguageQuery,

[ValidateRange(1,4096)]
[int]$MaxTokens = 1024
)

$apiKey = Read-Host -Prompt '输入OpenAI API密钥' -AsSecureString
$cred = New-Object System.Management.Automation.PSCredential ('api', $apiKey)

$body = @{
model = 'gpt-4-turbo-preview'
messages = @(
@{
role = 'system'
content = '你是一个PowerShell专家,将自然语言查询转换为可执行的PowerShell脚本。确保代码符合最佳安全实践,包含错误处理,并添加中文注释。'
},
@{
role = 'user'
content = $NaturalLanguageQuery
}
)
temperature = 0.2
max_tokens = $MaxTokens
} | ConvertTo-Json -Depth 5

try {
$response = Invoke-RestMethod -Uri 'https://api.openai.com/v1/chat/completions' \
-Method POST \
-Headers @{ Authorization = 'Bearer ' + $cred.GetNetworkCredential().Password } \
-ContentType 'application/json' \
-Body $body

$scriptBlock = [scriptblock]::Create($response.choices[0].message.content)
$transcript = [PSCustomObject]@{
Timestamp = Get-Date -Format 'yyyy-MM-dd HH:mm:ss'
OriginalQuery = $NaturalLanguageQuery
GeneratedScript = $response.choices[0].message.content
TokenUsage = $response.usage
}

$transcript | Export-Clixml -Path "$env:TEMP/AIScriptTranscript_$(Get-Date -Format yyyyMMdd).xml"
return $scriptBlock
}
catch {
Write-Error "AI脚本生成失败: $_"
}
}

核心功能

  1. 自然语言转PowerShell脚本
  2. 自动生成安全凭据处理
  3. 脚本转录与审计跟踪
  4. 智能温度控制与令牌限制

应用场景

  • 快速原型开发
  • 运维知识库建设
  • 跨团队协作标准化
  • 新人上岗培训