测试Remoting三种信道Http,Tcp,Ipc和Web Service的访问速度 (转)
Remoting和Web Service是.net中的重要技术,都可用来实现分布式系统开发,如果是不同的平台就只能选择Web Service,但如果是同一平台,就都可以选择了。到底选择那种,当然还有访问效率上的考虑,同时在Remoting中又有三中信道Http,Tcp,Ipc,它们又各有差别。HTTP方式的信道在跨越防火墙上有优势;TCP方式的信道常用在局域网内通信,速度比HTTP快很多;IPC信道用于同一台机器的进程间通信,通信不占用网络资源,速度又比TCP快很多。为了能够实际的比较一下这四者的实际访问速度,我写了个小程序用测试。这个程序的实现很简单利用Remoting三种信道和Web Service 访问同一个对象(相当于实际项目中的业务层),而这个对象实现返回系统的时间。就这么简单。如果有对Remoting和Web Service不太了解的,也可以通过我这个例子熟悉一下Remoting三种信道的写法差别和Web Service的调用。
下面是程序运行的界面,我使用.net中的最小时间度量:刻度(用毫秒在本机上可能都很难测出它们之间的差别),来测试每次调用所发的时间,并通过多次调用来测的一个平均时间来比较访问的速度。通过测试可以看得出他们四者得访问速度:ipc>tcp>http>Web Service.(其实Remoting的http信道和Web Service的访问速度还有待比较,跟测试的主机还有一定关系,在我办公室里的一台电脑上好像Web service的访问速度更快于http信道),大家可以自己测试一下,或研究一个比较好的方法。

//使用Http信道
public void Http()
{
Stopwatch stopWatch = new Stopwatch();
stopWatch.Start();
MyObject myObj = (MyObject)Activator.GetObject(typeof(MyObject), "http://localhost:9001/MyObject");
myObj.GetServerTime();
stopWatch.Stop();
lsbHttp.Items.Add(stopWatch.ElapsedTicks);
}
//使用Tcp信道
public void Tcp()
{
Stopwatch stopWatch = new Stopwatch();
stopWatch.Start();
MyObject myObj = (MyObject)Activator.GetObject(typeof(MyObject), "tcp://localhost:9002/MyObject");
myObj.GetServerTime();
stopWatch.Stop();
lsbTcp.Items.Add(stopWatch.ElapsedTicks);
}
//使用Ipc信道
public void Ipc()
{
Stopwatch stopWatch = new Stopwatch();
stopWatch.Start();
MyObject myObj = (MyObject)Activator.GetObject(typeof(MyObject), "Ipc://MyHost/MyObject");
myObj.GetServerTime();
stopWatch.Stop();
lsbIpc.Items.Add(stopWatch.ElapsedTicks);
}
//访问Web Service
public void WebService()
{
Stopwatch stopWatch = new Stopwatch();
stopWatch.Start();
localhost.Service ws = new localhost.Service();
ws.GetServerTime();
stopWatch.Stop();
lsbWeb.Items.Add(stopWatch.ElapsedTicks);
}
private void btnHttp_Click(object sender, EventArgs e)
{
Http();
}
private void btnTcp_Click(object sender, EventArgs e)
{
Tcp();
}
private void btnWebService_Click(object sender, EventArgs e)
{
WebService();
}
private void btnIpc_Click(object sender, EventArgs e)
{
Ipc();
}
//开始测试
private void btnStat_Click(object sender, EventArgs e)
{
Int32 Times = int.Parse(txtTimes.Text);
Int64 Sum = 0;
double Ave=0;
lsbHttp.Items.Clear();
lsbIpc.Items.Clear();
lsbTcp.Items.Clear();
lsbWeb.Items.Clear();
for (Int32 i = 0; i < Times; i++)
{
Http();
Tcp();
Ipc();
WebService();
}
//计算平均时间
for(Int32 i=0;i<Times;i++)
{
Sum += int.Parse(lsbHttp.Items[i].ToString ());
}
Ave = Sum / Times;
txtHttp.Text = Ave.ToString();
Sum = 0;
for (Int32 i = 0; i < Times; i++)
{
Sum += int.Parse(lsbTcp.Items[i].ToString());
}
Ave = Sum / Times;
txtTcp.Text = Ave.ToString();
Sum = 0;
for (Int32 i = 0; i < Times; i++)
{
Sum += int.Parse(lsbWeb.Items[i].ToString());
}
Ave = Sum / Times;
txtWebService.Text = Ave.ToString();
Sum = 0;
for (Int32 i = 0; i < Times; i++)
{
Sum += int.Parse(lsbIpc.Items[i].ToString());
}
Ave = Sum / Times;
txtIpc.Text = Ave.ToString();
}
HttpChannel httpChannel = new HttpChannel(9001);
ChannelServices.RegisterChannel(httpChannel,false );
TcpChannel tcpChannel = new TcpChannel(9002);
ChannelServices.RegisterChannel(tcpChannel,false );
IpcChannel ipcChannel = new IpcChannel("MyHost");
ChannelServices.RegisterChannel(ipcChannel,false );
RemotingConfiguration .RegisterWellKnownServiceType (typeof (RemoteObject .MyObject ),"MyObject",WellKnownObjectMode.SingleCall);
Console.ReadLine();/Files/zhang3533/RemotingAndWebService.rar
测试Remoting三种信道Http,Tcp,Ipc和Web Service的访问速度 (转)的更多相关文章
- .NET Remoting三种信道Http,Tcp,IPC和Web Service的访问速度比较(转)
Remoting和Web Service是.net中的重要技术,都可用来实现分布式系统开发,如果是不同的平台就只能选择Web Service,但如果是同一平台,就都可以选择了.到底选择那种,当然还有访 ...
- Java开发学习(三十二)----Maven多环境配置切换与跳过测试的三种方式
一.多环境开发 我们平常都是在自己的开发环境进行开发, 当开发完成后,需要把开发的功能部署到测试环境供测试人员进行测试使用, 等测试人员测试通过后,我们会将项目部署到生成环境上线使用. 这个时候就有一 ...
- shell 条件测试语句三种方法
1.test -f file 2.[ -f file ] 3.[[ -f file ]] [ -f file1 -a -f file2]逻辑与[ -f file1 -o -f file2]逻辑或 [ ...
- JS中三种字符串连接方式及其性能比较
工作中经常会碰到要把2个或多个字符串连接成一个字符串的问题,在JS中处理这类问题一般有三种方法,这里将它们一一列出顺便也对它们的性能做个具体的比较. 第一种方法 用连接符“+”把要连接的字符串连起来 ...
- JavaScript中三种字符串连接方式及其性能比较
参考地址: https://www.cnblogs.com/programs/p/5554742.html 工作中经常会碰到要把2个或多个字符串连接成一个字符串的问题,在JS中处理这类问题一般有三种方 ...
- STM32中AD采样的三种方法分析
在进行STM32F中AD采样的学习中,我们知道AD采样的方法有多种,按照逻辑程序处理有三种方式,一种是查询模式,一种是中断处理模式,一种是DMA模式.三种方法按照处理复杂方法DMA模式处理模式效率最高 ...
- angularjs 自定义服务的三种方式
angularjs 中可通过三种($provider,$factory,$service)方式自定义服务,以下是不同的实现形式: // 定义module , module中注入$providevar ...
- SpringMVC 拦截器不拦截静态资源的三种处理方式
SpringMVC提供<mvc:resources>来设置静态资源,但是增加该设置如果采用通配符的方式增加拦截器的话仍然会被拦截器拦截,可采用如下方案进行解决: 方案一.拦截器中增加针对静 ...
- tomcat-四种运行模式和三种部署模式(优化)
四中运行模式如下: 1-bio: 传统的Java I/O操作,同步且阻塞IO. 2-nio: JDK1.4开始支持,同步阻塞或同步非阻塞IO 3-aio(nio.2): JDK7开始支持,异步非阻塞I ...
随机推荐
- (五)unity4.6Ugui中文教程文档-------概要-UGUI Interaction Components
watermark/2/text/aHR0cDovL2Jsb2cuY3Nkbi5uZXQvdTAxMDAxOTcxNw==/font/5a6L5L2T/fontsize/400/fill/I0JBQk ...
- js判断访问者是否来自移动端代码
<script type="text/javascript"> function is_mobile() { var regex_match = /(nokia|iph ...
- Android自定义属性、控件三步法
第二步中layout-activity_main.xml 中自命名控件: xmlns:android="http://schemas.android.com/apk/res/android& ...
- 最小生成树--->NYOJ-38 布线问题
此题是最基础的最小生成树的题目,有两种方法, 一个是prim一个是kruskal算法,前者利用邻接矩阵,后者是利用边集数组 prim算法的思想是:一个点一个点的找, 先找从第一个点到其他点最小的, 把 ...
- SparseArray HashMap 稀疏数组 二分法
简介 HashMap是java里比较常用的一个集合类,我们常用其来缓存一些处理后的结果,但是在Android项目中,Eclipse却给出了一个 performance 警告.意思就是说用SparseA ...
- 5、第5节课CSS补充和html 标签讲解20150924
1. DIV 隐藏 A: 隐藏之后不占位置 display:none; B:隐藏之后占位置 visibility:hidden; 2.DIV 排序 z-index:2; 默认是1,如果想DIV在上 ...
- MySQL安装与测试
工作室老师要求我们把MySQL装出来 今天折腾了下,本来不难的,不知道为什么用最新5.6.24的msi安装包,安装的时候选完路径后就没有后续了..蛋疼的我试了好几次,用cmd命令测试一直是 2003- ...
- 第一章 初识Lucene
多看几遍,慢就是快 1.1 应对信息爆炸 1.2 Lucene 是什么 1.2.1 Lucene 能做些什么 1.2.2 Lucene 的历史 1.3 Lucene 和搜索程序组件 基本概念 索引操作 ...
- Arcgis Android 基本概念 - 浅谈
MapView MapView 是 Android 中 ViewGroup的子类,也是 ArcGIS Runtime SDK for Android 中的地图容器,与很多 ArcGIS API ...
- oracle 数据库开发面试题,当时笔试的时候一个没做出来,现附原题及答案
1. ID123567810111215 表名tt,用sql找出ID列中不连续的ID,例如其中没有的4: --创建表及数据 CREATE TABLE tt(ID INTEGER); INSERT IN ...