我写了下面的Powershell函数来调用F5单元。它为每个服务器循环,获取每个单独的stat,然后执行SQL SMO调用。
代码运行速度非常慢,我认为我已将SQL调用打折为原因。
如何改进powershell?
function Print-VServerStats()
{
param($virtual_server);
$VirtualServerStatistics = (Get-F5.iControl).LocalLBVirtualServer.get_statistics( (, $virtual_server) );
$VirtualServerStatisticEntry = $VirtualServerStatistics.statistics[0];
$Statistics = $VirtualServerStatisticEntry.statistics | ? {$_.type -eq "STATISTIC_CLIENT_SIDE_CURRENT_CONNECTIONS" -or
$_.type -eq "STATISTIC_CLIENT_SIDE_MAXIMUM_CONNECTIONS" -or
$_.type -eq "STATISTIC_CLIENT_SIDE_TOTAL_CONNECTIONS"};
foreach ($Statistic in $Statistics)
{
$val = Convert-To64Bit $Statistic.value.high $Statistic.value.low;
switch ($Statistic.type) {
"STATISTIC_CLIENT_SIDE_CURRENT_CONNECTIONS" {
$label = "Current Connections";
}
"STATISTIC_CLIENT_SIDE_MAXIMUM_CONNECTIONS" {
$label = "Max Connections";
}
"STATISTIC_CLIENT_SIDE_TOTAL_CONNECTIONS" {
$label = "Total Connections";
}
}
$profcmd.Parameters["@property"].Value = $SrceName
$profcmd.Parameters["@propertyDesc"].Value = $label
$profcmd.Parameters["@ValDim1"].Value = $virtual_server
$profcmd.Parameters["@value"].Value = $val
$profcmd.Parameters["@Timestamp"].Value = $t
[void]$profcmd.ExecuteNonQuery()
}
}
答案 0 :(得分:0)
我们有一个F5 BigIP,我们注意到设备上的用户界面真的很慢。我们没有找到原因,但很可能你的延迟是在F5设备上采购。
上的测量命令$VirtualServerStatistics = (Get-F5.iControl).LocalLBVirtualServer.get_statistics( (, $virtual_server) );
如果是这样的话,应该显示出来。
答案 1 :(得分:0)