目录
  • .NET Remoting学习笔记(一)概念
  • .NET Remoting学习笔记(二)激活方式
  • .NET Remoting学习笔记(三)信道
  • 参考:♂风车车.Net

    .NET Framework 远程处理基础结构提供下列信道实现:
  • IpcChannel
  • TcpChannel
  • HttpChannel
  • IpcChannel

    IPCChannel是.NET Framework 2.0 里面新增的,它使用 Windows 进程间通信 (IPC) 系统在同一计算机上的应用程序域之间传输消息。在同一计算机上的应用程序域之间进行通信时,IPC 信道比 TCP 或 HTTP 信道要快得多。但是IPC只在本机应用之间通信。所以,在客户端和服务端在同一台机器时,我们可以通过注册IPCChannel来提高Remoting的性能。但如果客户端和服务端不在同一台机器时,我们不能注册IPCChannel。

    IpcChannel 执行下列功能:

  • 使用命名管道在发送方和接收方之间通信。
  • 支持以二进制格式和行业标准 SOAP 序列化格式编码负载。
  • 生成并使用对象引用的 ChannelDataStore。
  • 支持模拟和委托。
  • 支持在命名管道上利用访问控制列表 (ACL) 来提供高级访问控制。
  • TcpChannel

    TcpChannel 类使用二进制格式化程序将所有消息序列化为二进制流,并使用 TCP 协议将该流传输至目标统一资源标识符 (URI)。

    TcpChannel 执行下列功能:

  • 使用 TCP 套接字在发送方和接收方之间通信。
  • 支持以二进制格式和行业标准 SOAP 序列化格式编码负载。
  • 生成并使用对象引用的 ChannelDataStore。
  • 支持模拟和委托。
  • 支持 SSPI 加密。
  • HttpChannel

    HttpChannel 类使用 SOAP 协议在远程对象之间传输消息。所有消息都通过 SoapFormatter 传递,此格式化程序会将消息转换为 XML 并进行序列化,同时向数据流中添加所需的 SOAP 标头。如果还指定了二进制格式化程序,则会创建二进制数据流。随后,将使用 HTTP 协议将数据流传输至目标 URI。

    HttpChannel 符合 SOAP 1.1 标准,它执行下列功能:

  • 通过将 HTTP 协议用作传输在发送方和接收方之间通信。
  • 支持以 SOAP(一种 XML 编码标准)和二进制格式编码负载。
  • 将接收方设置为通过 ASP.NET 和 TCP 套接字接收 HTTP 请求并发送 HTTP 响应。
  • 生成并使用对象引用的 ChannelDataStore。
  • 支持模拟和委托。
  • 支持 SSPI 加密。
  • 下面贴代码:

    1.定义远程对象

    using System;
    using System.Runtime.Remoting.Metadata; namespace MessageMarshal
    {
    /*创建发送消息委托*/
    public delegate void SendMessageHandler(string messge); [Serializable]
    public class TestMessageMarshal : MarshalByRefObject
    {
    private Guid ID { get; set; } /*新建对象实例时重新创建标识编号*/
    public TestMessageMarshal()
    {
    ID = Guid.NewGuid();
    } /*创建发送消息事件*/
    public static event SendMessageHandler SendMessageEvent; /*发送消息*/
    [SoapMethod(XmlNamespace = "MessageMarshal", SoapAction = "MessageMarshal#SendMessage")]
    public void SendMessage(string messge)
    {
    if (SendMessageEvent != null)
    SendMessageEvent(ID.ToString() + "\t" + messge);
    }
    }
    }

    2.定义服务端

    using System;
    using System.Runtime.Remoting;
    using System.Runtime.Remoting.Channels;
    using System.Runtime.Remoting.Channels.Tcp; namespace TestRemotingServer
    {
    public class Program
    {
    static void Main(string[] args)
    {
    Console.WriteLine("创建HTTP通道"); /*创建HTTP通道*/
    TcpChannel channel = new TcpChannel(816); /*注册通道服务端*/
    ChannelServices.RegisterChannel(channel, false);
    RemotingConfiguration.ApplicationName = "test"; /*服务端注册,使用SingleCall激活*/
    RemotingConfiguration.RegisterActivatedServiceType(typeof(MessageMarshal.TestMessageMarshal)); Console.WriteLine("started ..."); /*接收客户端事件*/
    MessageMarshal.TestMessageMarshal.SendMessageEvent += new MessageMarshal.SendMessageHandler(TestMessageMarshal_SendMessageEvent); Console.Read();
    } static void TestMessageMarshal_SendMessageEvent(string messge)
    {
    Console.WriteLine(messge);
    }
    }
    }

    3.定义客户端:

    using System;
    using System.Runtime.Remoting;
    using System.Runtime.Remoting.Channels;
    using System.Runtime.Remoting.Channels.Tcp;
    using System.Threading; namespace TestRemotingClient
    {
    class Program
    {
    static void Main(string[] args)
    {
    /*创建通道*/
    TcpChannel channel = new TcpChannel(); /*注册通道*/
    ChannelServices.RegisterChannel(channel, false); /*注册通道 的 远程处理类型*/
    RemotingConfiguration.RegisterActivatedClientType(typeof(MessageMarshal.TestMessageMarshal), "tcp://localhost:816/test"); /*创建消息实体*/
    MessageMarshal.TestMessageMarshal TestMessage = new MessageMarshal.TestMessageMarshal(); while (true)
    {
    TestMessage.SendMessage("DateTime.Now:" + System.DateTime.Now.ToString());
    Console.WriteLine("send message...");
    Thread.Sleep(2000);
    }
    }
    }
    }

    4.测试

    定义为TcpChannel 时

    定义服务端:

    using System;
    using System.Runtime.Remoting;
    using System.Runtime.Remoting.Channels;
    using System.Runtime.Remoting.Channels.Ipc; namespace TestRemotingServer
    {
    public class Program
    {
    static void Main(string[] args)
    {
    Console.WriteLine("创建ICP通道"); /*创建HTTP通道*/
    IpcServerChannel channel = new IpcServerChannel("Server"); /*注册通道服务端*/
    ChannelServices.RegisterChannel(channel, false);
    RemotingConfiguration.ApplicationName = "test"; /*客户端激活*/
    RemotingConfiguration.RegisterActivatedServiceType(typeof(MessageMarshal.TestMessageMarshal)); /*接收客户端事件*/
    MessageMarshal.TestMessageMarshal.SendMessageEvent += new MessageMarshal.SendMessageHandler(TestMessageMarshal_SendMessageEvent); Console.Read();
    } static void TestMessageMarshal_SendMessageEvent(string messge)
    {
    Console.WriteLine(messge);
    }
    }
    }

    定义客户端:

    using System;
    using System.Runtime.Remoting;
    using System.Runtime.Remoting.Channels;
    using System.Runtime.Remoting.Channels.Ipc;
    using System.Threading; namespace TestRemotingClient
    {
    class Program
    {
    static void Main(string[] args)
    {
    /*创建通道*/
    IpcClientChannel channel = new IpcClientChannel(); /*注册通道*/
    ChannelServices.RegisterChannel(channel, false); /*注册通道 的 远程处理类型*/
    RemotingConfiguration.RegisterActivatedClientType(typeof(MessageMarshal.TestMessageMarshal), "ipc://Server/test"); /*创建消息实体*/
    MessageMarshal.TestMessageMarshal TestMessage = new MessageMarshal.TestMessageMarshal(); while (true)
    {
    TestMessage.SendMessage("DateTime.Now:" + System.DateTime.Now.ToString());
    Console.WriteLine("send message...");
    Thread.Sleep(2000);
    }
    }
    }
    }

    运行结果

    .NET Remoting 咱只写三篇 应该能给大家带来些了解,应对面试

    作者:释迦苦僧 出处:http://www.cnblogs.com/woxpp/p/3997984.html

    本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。

    【转载】.NET Remoting学习笔记(三)信道的更多相关文章

    1. .NET Remoting学习笔记(三)信道

      目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 参考:♂风车车.Net .NET Framework ...

    2. 【转载】.NET Remoting学习笔记(二)激活方式

      目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 参考:百度百科 ♂风车车.Net 激活方式概念 在访 ...

    3. 【转载】.NET Remoting学习笔记(一)概念

      目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 背景 自接触编程以来,一直听过这个名词Remotin ...

    4. .NET Remoting学习笔记(二)激活方式

      目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 参考:百度百科  ♂风车车.Net 激活方式概念 在 ...

    5. .NET Remoting学习笔记(一)概念

      目录 .NET Remoting学习笔记(一)概念 .NET Remoting学习笔记(二)激活方式 .NET Remoting学习笔记(三)信道 背景 自接触编程以来,一直听过这个名词Remotin ...

    6. JSP学习笔记(三):简单的Tomcat Web服务器

      注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...

    7. 学习笔记(三)--->《Java 8编程官方参考教程(第9版).pdf》:第十章到十二章学习笔记

      回到顶部 注:本文声明事项. 本博文整理者:刘军 本博文出自于: <Java8 编程官方参考教程>一书 声明:1:转载请标注出处.本文不得作为商业活动.若有违本之,则本人不负法律责任.违法 ...

    8. JAVA WEB学习笔记(三):简单的基于Tomcat的Web页面

      注意:每次对Tomcat配置文件进行修改后,必须重启Tomcat 在E盘的DATA文件夹中创建TomcatDemo文件夹,并将Tomcat安装路径下的webapps/ROOT中的WEB-INF文件夹复 ...

    9. MYSQL学习笔记三:日期和时间函数

      MYSQL学习笔记三:日期和时间函数 1. 获取当前日期的函数和获取当前时间的函数 /*获取当前日期的函数和获取当前时间的函数.将日期以'YYYY-MM-DD'或者'YYYYMMDD'格式返回 */ ...

    随机推荐

    1. Spring,Mybatis,Springmvc框架整合项目(第二部分)

      一.创建数据库表 打开Navicat Premium,点击左上角连接,选择mysql   输入你的数据库用户名和密码信息,可以先点击下测试连接,如果显示连接成功,说明能连接到数据库,然后点击确定.如果 ...

    2. PAT Basic 1030

      1030 完美数列 给定一个正整数数列,和正整数p,设这个数列中的最大值是M,最小值是m,如果M <= m * p,则称这个数列是完美数列. 现在给定参数p和一些正整数,请你从中选择尽可能多的数 ...

    3. IOS 自动布局-UIStackPanel和UIGridPanel(二)

      在上一篇中我提到了如何使用stackpanel和gridpanel来实现自动布局.而在这一篇中我着重讲解下其中的原理. 在(UIPanel   UIStackPanel  UIGridPanel)中主 ...

    4. 大数据学习——Storm学习单词计数案例

      需求:计算单词在文档中出现的次数,每出现一次就累加一次 遇到的问题 这个问题是<scope>provided</scope>作用域问题 https://www.cnblogs. ...

    5. LeetCode--二分查找相关算法

      -(1)有一个升序排列的非负数组,要求利用o(logn)的时间复杂度找到数组中确定数字target的第一次出现的位置下标和最后一次出现的位置下标,如果不存在该target返回[-1,-1] 解决方案: ...

    6. 【数位DP】HDU 6156 Palindrome Function

      http://acm.hdu.edu.cn/showproblem.php?pid=6156 [AC] #include<bits/stdc++.h> using namespace st ...

    7. kail Linux 安装Parallels Tools

      网上好多都是Parallels8的 针对Parallels 9 的还真不好找..... 自己捣鼓了一阵 终于可以安装了,但还是有错误,因为公司网络太不给力....回家再测试吧 1.在桌面新建一个文件夹 ...

    8. 解决 Mac OS X Retina 屏幕显示环境下 jEdit 字体模糊的方法

      Mac OS X Retina 屏幕显示环境下,字体非常清晰.但是 jEdit 仍然很模糊,虽然 jEdit 用的是 Java,但这并不是理由.因为诸如 NetBeans 以及 IntelliJ ID ...

    9. 马蜂窝ABTest多层分流系统的设计与实现

        什么是 ABTest 产品的改变不是由我们随便「拍脑袋」得出,而是需要由实际的数据驱动,让用户的反馈来指导我们如何更好地改善服务.正如马蜂窝 CEO 陈罡在接受专访时所说:「有些东西是需要 Sen ...

    10. DispatcherServlet url-pattern中 /、/*、*.do中的区别与作用

      DispatcherServlet url-pattern中 /./*.*.do中的区别与作用 "/'表示匹配所有请求(其中包含除.jsp和.jspx外的所有后缀). 如果不配置静态资源,它 ...