Я использую NSCLient для выполнения некоторых проверок NRPE в ящиках Windows Server. Проверки запускают сценарии Powershell, но у меня проблема в том, что NSClient добавляет случайные разрывы строк после 79 символов. Я предполагаю, что это потому, что ширина консоли Powershell / CMD по умолчанию составляет 80 символов (это правильно?), Но мне нужна проверка, чтобы не добавьте эти новые строки (они портят данные о производительности, и Nagios расстраивается).
Я пробовал изменить размер консоли из стандартного экземпляра Powershell, но это не сработало, есть ли способ указать размер консоли с помощью флага командной строки? Файлы справки были не очень полезны.
Пример вывода, который я получаю от Nagios check_nrpe
vmxnet3 ethernet adapter _2:728.370961294234isatap.{1c6435bc-27c9-452b-a6fe-668^M
dced31461}:0| 'Network Usage (Bytes/sec) (vmxnet3 ethernet adapter _2)'=728.370^M
961294234 'Network Usage (Bytes/sec) (isatap.{1c6435bc-27c9-452b-a6fe-668dced31^M
461})'=0
(Проблема не в управляющих символах, Nagios, похоже, их не замечает, а в самих новых строках)
Скрипт Powershell;
#
# Check Network Usage
#
#Check for argument variables
if ( $($args.count) -lt 2 ) {
"Usage: ./check_network.ps1 [warn level] [crit level]"
exit 3
}
$warn = [int]$args[0]
$crit = [int]$args[1]
#Create buffers for the Nagios output
$ExitStatus = 0
$TextOP = ""
$PerfDataOP = ""
#Get the average network usage for the last 5 seconds
$PerfData = Get-Counter -Counter "\network interface(*)\bytes total/sec" -SampleInterval 5 -MaxSamples 1
foreach($InterfacePerf in $PerfData.CounterSamples) {
#Write the outputs
$TextOP = %{"{0}" -f $TextOP,$InterfacePerf.InstanceName,$InterfacePerf.CookedValue}
$PerfDataOP = %{"{0} 'Network Usage (Bytes/sec) ({1})'={2}" -f $PerfDataOP,$InterfacePerf.InstanceName,$InterfacePerf.CookedValue}
#Trigger alerts
#If level is higher than crit, and the status is 'OK' or 'Warn'
if ( $InterfacePerf.CookedValue -gt $crit -and $ExitStatus -lt 2 ) {
$ExitStatus = 2
} elseif ( $InterfacePerf.CookedValue -gt $warn -and $ExitStatus -eq 0 ) {#warning
$ExitStatus = 1
}
}
#Exit and return status
"$TextOP|$PerfDataOP"
exit $ExitStatus
Я успешно выполнил следующий код с тестовым образцом для создания длинной строки ...
if( $Host -and $Host.UI -and $Host.UI.RawUI ) {
$rawUI = $Host.UI.RawUI
$oldSize = $rawUI.BufferSize
$typeName = $oldSize.GetType( ).FullName
$newSize = New-Object $typeName (101, $oldSize.Height)
$rawUI.BufferSize = $newSize
}
$longstring = ""
1..200 | %{$longstring += "a"}
$longstring
Очевидно, что самая важная часть - это верхняя часть. $longstring
просто я делаю длинную строку. Вы также можете сократить это до:
$Host.UI.RawUI.BufferSize = New-Object Management.Automation.Host.Size (101, 25)
Это устраняет любые виды тестирования перед установкой значений.
Я установил ширину 101, чтобы видеть четкую обертку линии.
У меня нет возможности проверить вашу ситуацию, но, надеюсь, это поможет:
"$TextOP|$PerfDataOP" | Out-String -Width 1024