Remoting使用情况性能测试(二)
测试环境:
Server: P4 2.4G 1G内存
Client: P4 1.8G 1G 内容
Client使用ASP.NET 2.0创建远程对象;然后通过ACT对Clinet进行测试。
服务端代码:
ChannelServices.RegisterChannel(new HttpChannel (8081));
WellKnownServiceTypeEntry myWellKnownServiceTypeEntry =
new WellKnownServiceTypeEntry(typeof(HFSoft.ObjectService.Server),
"TestLogic",
WellKnownObjectMode.Singleton);
RemotingConfiguration.RegisterWellKnownServiceType(
myWellKnownServiceTypeEntry);
Console.WriteLine("Started the Server port:8081, Hit <enter> to exit...");
客户端代码:
using (ICreateInstance<TestLogic.Employee> logic =
ObjectFactory.ConfigObjectFactory.CreateInstance<TestLogic.Employee>())
{
//logic.Source.EmployeeID = 1;
logic.Source.Load();
}
客户端配置方式:
<objectservice>
<!--<server url="192.168.0.62:8081/TestLogic" type="http">
<objecttype type="TestLogic.Employee,TestLogic"/>
</server>-->
<server url="192.168.0.235:8081/TestLogic" type="http">
<objecttype type="TestLogic.Employee,TestLogic"/>
</server>
</objectservice>
可以配置多个服务器,由组件随机选择相关服务器。
(1) |
测试名称: |
ACTSamples: ObjectServiceTest |
|
测试运行名称: |
创建远程服务对象,并返回远程业务对象和设置业务对象一成员值、执行业务对象方法(在Client缓存10个相关代理对象) |
|
测试开始时间: |
2006-9-26 |
|
测试持续时间: |
|
|
测试迭代次数: |
6,792 |
|
测试说明: |
- |
(2) |
测试名称: |
ACTSamples: ObjectServiceTest |
|
测试运行名称: |
创建远程服务对象,并返回远程业务对象和执行业务对象方法(在Client缓存20个相关代理对象) |
|
测试开始时间: |
2006-9-26 |
|
测试持续时间: |
|
|
测试迭代次数: |
9,008 |
|
测试说明: |
- |
(3) |
测试名称: |
ACTSamples: ObjectServiceTest |
|
测试运行名称: |
创建远程服务对象,并返回远程业务对象 |
|
测试开始时间: |
2006-9-26 |
|
测试持续时间: |
|
|
测试迭代次数: |
7,414 |
|
测试说明: |
- |
(4) |
测试名称: |
ACTSamples: ObjectServiceTest |
|
测试运行名称: |
创建远程服务对象,并返回远程业务对象和执行业务对象方法(在Client缓存10个相关代理对象) |
|
测试开始时间: |
2006-9-26 |
|
测试持续时间: |
|
|
测试迭代次数: |
8,921 |
|
测试说明: |
- |
(5) |
测试名称: |
ACTSamples: ObjectServiceTest |
|
测试运行名称: |
创建远程服务对象,并返回远程业务对象和执行业务对象方法 |
|
测试开始时间: |
2006-9-26 |
|
测试持续时间: |
|
|
测试迭代次数: |
5,500 |
|
测试说明: |
- |
测试运行图形
显示错误
基于远程代理的对象调用,成员的操作对性能影响还是比较大的。从2和1测试用例对比可以看到,只是多了一个成员的调用并发率竟然能相差这么大。因此在调用远程对象时最好是基于无状态方法的调用,这样可以减少远程对象的访问次数,从而获取性能上的提高。
缓存的利用也是一个很重要的因素,这样可以避免远对象创建过程中带来的损耗问题。直接由RemotingConfiguration配置代理的对象内部已经提供这处机制,如果代理对象是通过另一个代理创建时缓存就变得很重要从2和5的测试图可以看到差别。多层代理对象的创建对性能的影响比较严重,因此遇到这情况要特别注意。