Win32_Printer远程WMI查询真的很慢

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

我正在尝试更新远程服务器上某些打印机的一些信息。我需要更新位置、评论和端口等内容。我有一个可行的解决方案,但我发现它非常慢,我想知道是否有人知道为什么。

我通过 WMI 从服务器获取打印机(以及后来的端口),代码如下:(这是测试代码)

var test = DateTime.Now;
ManagementScope scope3 = new ManagementScope("\\\\printserver\\root\\cimv2");
scope3.Connect();
SelectQuery q3 = new SelectQuery("select * from Win32_Printer WHERE Name = 'printername'");
ManagementObjectSearcher search3 = new ManagementObjectSearcher(scope3, q3);
var printers3 = search3.Get();
foreach(var p in printers3)
{
    //do stuff with printer here.
}
var test2 = DateTime.Now.Subtract(test).TotalSeconds;

完成后,test2 将包含“33.something”秒。 如果我在没有 where 子句的情况下执行此操作,则几乎需要相同的时间。诚然,该服务器上有近 1500 台打印机,但我觉得我应该能够以更快的方式查询一台特定的打印机,而且我不明白为什么在打印机名称上使用 where 子句的查询会采取相同的方式作为“全选”查询的时间。

有什么建议吗?

--

更新

正如下面所建议的,我尝试多次运行相同的查询。仍然需要相同的时间。当我搜索特定打印机时,Windows 需要“触摸”系统上的每台打印机,这让我感觉很奇怪。

c# wmi printers
2个回答
3
投票

无可否认,该服务器上有近 1500 台打印机

这当然是令人讨厌的小细节。每台打印机需要 33 / 1500 = 0.022 秒。在计算机中,这是一个非常神奇的数字,大约是在主轴磁盘上打开一个文件需要多长时间。

您可以执行一个简单的测试来检查磁盘是否确实是瓶颈。只需在慢速查询之后第二次运行查询即可。文件信息现在将缓存在文件系统缓存中,它应该在不到一秒的时间内执行。您可能已经这样做了,请用您发现的内容更新您的问题。

当然,你在软件中对此无能为力。服务器需要更好的硬件才能让您满意。 SSD 非常好,应该可以轻松地将速度提高 20 倍。更多的 RAM 可以有所帮助,但不是黄金解决方案。更频繁地访问服务器,以便将文件数据保留在缓存中是一种解决方法,对服务器不太友好。


0
投票

我会参考这个主题中的答案 真是太棒了,而且比 select 快得多

© www.soinside.com 2019 - 2024. All rights reserved.