猿问

WCF获得客户端的内存信息慢(特定客户端Server 2008 R2 SP1+64位操作系统)

功能描述:服务器端获得客户端的硬件信息。绝大多数都正常,只有一种情况不正常。

特定客户端系统信息:Windows Server 2008 R2 SP1

系统类型:64位操作系统

在该客户端本机获得总内存和可用内存信息平均需要280毫秒。 但远程WCF调用需要50多秒。

经过调研在其他的客户端上都正常,上面这一种(Server 2008 R2+64位操作系统)获得内存信息特别慢,而获得其他硬件信息(比如CPU信息、光驱等)正常。感觉是WCF的问题(本机很正常,远程调用慢),不知道怎么解决,还望了解的指点一二。

WCF的绑定是netTcpBinding的,下面是绑定的配置文件

<bindings> <netTcpBinding>     

    <binding name="tcpBinding" receiveTimeout="24.00:00:00" transferMode="Buffered" maxReceivedMessageSize="2147483647">           <reliableSession inactivityTimeout="24.00:00:00"/>  

<security mode="None">

<transport clientCredentialType="None" protectionLevel="None"/>             <message clientCredentialType="None" algorithmSuite="Default"/>           </security>   

</binding>

</netTcpBinding></bindings>

获得内存信息的代码

Stopwatch sw = new Stopwatch();

sw.Start();           

//总内存大小           

ulong MemoryCapacity = 0;      

//可用内存大小          

ulong MemoryOccupancy = 0;       

ManagementClass memoryHelper = new ManagementClass("Win32_PhysicalMemory");          

ManagementObjectCollection moc = memoryHelper.GetInstances();             foreach (ManagementObject m in moc)             {

 MemoryCapacity = ulong.Parse(m.Properties["Capacity"].Value.ToString()) / 1024 / 1024;        

     }      

//获取内存可用大小         

memoryHelper = new ManagementClass("Win32_PerfFormattedData_PerfOS_Memory");     

moc = memoryHelper.GetInstances();        

foreach (ManagementObject m in moc)             {   

MemoryOccupancy = ulong.Parse(m.Properties["AvailableMBytes"].Value.ToString());      

}           

Console.WriteLine("获取内存信息耗时(单位毫秒):"+sw.ElapsedMilliseconds); sw.Stop();         

Console.ReadLine();

青春有我
浏览 628回答 10
10回答

Smart猫小萌

1 本机和远程用的是同一个wcf服务吗? 不是的话和账号可能有关 2 localhost访问wcf是否正常? 3 如果仍有问题,你可以使用VS的“分析、探查器”采样一下程序,看哪个函数在耗时

呼啦一阵风

本机模拟服务端和客户端时正常,服务端和客户端是双工的,服务端发出请求,客户端执行读取内存信息返回给服务端。绝大多数的都正常,只有 Server 2008 R2 SP1+64位操作系统的才会慢。我逐步写日志的,发现是在读内存的地方耗时的。 另外我还写了个单独获得内存的控制台程序,在那种机型上测试,只要280毫秒。

元芳怎么了

@MoonSky: 控制台程序和双工的客户端程序的设置区别在哪里,是否这些引起的? 另外看看系统的日志查看器 有没有告警什么的,也是线索

临摹微笑

@2012: 调用的是相同的函数,不同之处一个是直接调用获取内存信息的函数,一个是远程WCF调用那个执行获取内存信息的函数。系统的日志查看器里面是看不到任何警告或者报错的信息的。没有错误只是慢。

茅侃侃

单从64位操作系统和你的new ManagementClass("Win32_PhysicalMemory");来看,可以推断出问题是64位系统调用了32位的API造成的问题,正常情况下,64位系统应该调用64位的API,除非项目编译选项里强制指定该程序是32位运行的,默认的Any PC方式会在64位系统下,按照64位模式运行,所有.NET的方法全部调用64位的API。 你尝试将客户端项目强制运行在X86模式下面,估计就能好了。

慕仙森

尝试了,没看到变快的效果。

波斯汪

确定是程序慢还是请求过程慢

素胚勾勒不出你

是程序慢,把获取内存信息的那段注释掉,别的瞬间完成。单独执行那个函数快,但用WCF调用那个函数就慢。
随时随地看视频慕课网APP
我要回答