希望有人能帮助我弄清楚这是否可能。 我有 20 行左右的行,可以在 while 循环中扫描日志文件。 我需要与脚本的其余部分并行发生。 日志扫描循环将条目传递到 SQLite 中,其他脚本需要对此信息进行操作 - 因此希望并行运行它们。
如果我使用 Job-Start 命令,那么 -SciptBlock 函数似乎只接受一行管道命令。 我有太多命令要管道,所以我需要在脚本块中运行多行。
我尝试了几种方法,但以下示例给出的错误最少。 我还在调用命令 -ScriptBlock 中尝试了它 - 就像第二个示例一样 - 两种方式都不会接受多行脚本块。
请问我做错了什么?
Start-Job -Name LogScan -ScriptBlock
{
$EventOld = ConvertFrom-Json (Get-content ( Get-ChildItem | Sort-Object -Property LastWriteTime | Select-Object -last 1 ) | Select-Object -last 1)
$RunLoop = 1
while (RunLoop -ge 1)
{
Start-Sleep -Milliseconds 333
$RunLoop = $RunLoop +1
$EventNew = ConvertFrom-Json (Get-content ( Get-ChildItem | Sort-Object -Property LastWriteTime | Select-Object -last 1 ) | Select-Object -last 1)
if ($EventOld.timestamp -ne $EventNew.timestamp)
{
# lots of commands and here passing the array to SQLite
}
$EventOld = $EventNew
}
}
错误如下:
Start-Job : Missing an argument for parameter 'ScriptBlock'.
Specify a parameter of type 'System.Management.Automation.ScriptBlock'
and try again. [..]
briantist 帮助我到达那里:)
使用 Start-Job
和 Invoke-Command
时,请注意将 -ScriptBlock 参数的开头{
与命令放在同一行上。 不要像使用 if
或 while
命令那样将其放在下面的行中。
这导致了一个进一步的问题,即没有发现您没有正确匹配左{
和右}
括号,因为您习惯于匹配它们的缩进级别以将它们配对的惯例。
请注意,代码中$Event.timestamp
对引用。这些来自这样一个事实,即其中一个 JSON 字段被称为 timestamp
- 它不是标准字符串或数组的方法或属性。