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的访问速度 (转)的更多相关文章

  1. .NET Remoting三种信道Http,Tcp,IPC和Web Service的访问速度比较(转)

    Remoting和Web Service是.net中的重要技术,都可用来实现分布式系统开发,如果是不同的平台就只能选择Web Service,但如果是同一平台,就都可以选择了.到底选择那种,当然还有访 ...

  2. Java开发学习(三十二)----Maven多环境配置切换与跳过测试的三种方式

    一.多环境开发 我们平常都是在自己的开发环境进行开发, 当开发完成后,需要把开发的功能部署到测试环境供测试人员进行测试使用, 等测试人员测试通过后,我们会将项目部署到生成环境上线使用. 这个时候就有一 ...

  3. shell 条件测试语句三种方法

    1.test -f file  2.[ -f file ] 3.[[ -f file ]] [ -f file1 -a -f file2]逻辑与[ -f file1 -o -f file2]逻辑或 [ ...

  4. JS中三种字符串连接方式及其性能比较

    工作中经常会碰到要把2个或多个字符串连接成一个字符串的问题,在JS中处理这类问题一般有三种方法,这里将它们一一列出顺便也对它们的性能做个具体的比较. 第一种方法  用连接符“+”把要连接的字符串连起来 ...

  5. JavaScript中三种字符串连接方式及其性能比较

    参考地址: https://www.cnblogs.com/programs/p/5554742.html 工作中经常会碰到要把2个或多个字符串连接成一个字符串的问题,在JS中处理这类问题一般有三种方 ...

  6. STM32中AD采样的三种方法分析

    在进行STM32F中AD采样的学习中,我们知道AD采样的方法有多种,按照逻辑程序处理有三种方式,一种是查询模式,一种是中断处理模式,一种是DMA模式.三种方法按照处理复杂方法DMA模式处理模式效率最高 ...

  7. angularjs 自定义服务的三种方式

    angularjs 中可通过三种($provider,$factory,$service)方式自定义服务,以下是不同的实现形式: // 定义module , module中注入$providevar ...

  8. SpringMVC 拦截器不拦截静态资源的三种处理方式

    SpringMVC提供<mvc:resources>来设置静态资源,但是增加该设置如果采用通配符的方式增加拦截器的话仍然会被拦截器拦截,可采用如下方案进行解决: 方案一.拦截器中增加针对静 ...

  9. tomcat-四种运行模式和三种部署模式(优化)

    四中运行模式如下: 1-bio: 传统的Java I/O操作,同步且阻塞IO. 2-nio: JDK1.4开始支持,同步阻塞或同步非阻塞IO 3-aio(nio.2): JDK7开始支持,异步非阻塞I ...

随机推荐

  1. 数字信号处理Day2-小波基与规范正交化

    我们有这么一张灰度图64*64 我们能够定义出4096个基,各自是某一位是0其它是1,在这样的情况下,假设我们传输图片,那么就相当于传输原始数据 如果传到一半,网络坏了. 于是,我们得到 我们能够计算 ...

  2. Android中Application类用法

    Application类 Application和Activity,Service一样是Android框架的一个系统组件,当Android程序启动时系统会创建一个Application对象,用来存储系 ...

  3. Asp.Net WebAPI 中Cookie 获取操作方式

    1. /// <summary> /// 获取上下文中的cookie /// </summary> /// <returns></returns> [H ...

  4. Linux误删C基本运行库libc.so.6急救方法

    首先普及一下关于libc.so.6的基本常识: libc.so.6是glibc的软链接 ll  /lib64/libc.so.6lrwxrwxrwx 1 root root 11 Aug 27 201 ...

  5. CentOS 6.4搭建zabbix

    系统环境:CentOS 6.4 64bit Zabbix版本:zabbix 2.2.3 前提条件:已安装好LNMP环境 一.服务端: 1.  下载zabbix安装包zabbix-2.2.3.tar.g ...

  6. 【转】深入理解Java内存模型(六)——final

    与前面介绍的锁和volatile相比较,对final域的读和写更像是普通的变量访问.对于final域,编译器和处理器要遵守两个重排序规则: 在构造函数内对一个final域的写入,与随后把这个被构造对象 ...

  7. preventDefault() 方法 取消掉与事件关联的默认动作

    前几天写的 响应键盘的图片切换 中, 键盘总是让浏览器滚动,为了取消掉默认的事件,使用了 preventDefault() 方法 定义和用法 preventDefault() 方法取消事件的默认动作. ...

  8. MFC 全局配置 读取保存配置

    不知道关于全局配置别人都是怎么处理的,最近做的东西都用到全局配置,而且要保存软件的设置,下次启动时要使用上次关闭时的配置. 我的做法是建一个类用来保存和读取配置,并且在这个类中创建一些变量,供所有的界 ...

  9. BIOS+MBR模式 VS UEFI+GPT模式

     EFI与MBR启动的区别 大硬盘和WIN8系统,让我们从传统的BIOS+MBR模式升级到UEFI+GPT模式,现在购买的主流电脑,都是预装WIN8系统,为了更好的支持2TB硬盘 ,更快速的启动win ...

  10. linux笔记2.20

    用户相关:  /etc/passwd  用户信息 /etc/shadow  密码信息 /etc/group  组信息 添加用户:   useradd   -u -g 修改用户: usermod   - ...