【转】.NET Remoting

.Net Remoting提供了一种允许一个应用域中的对象与另一个应用域中的对象进行交互的框架。是.NET框架中的一个重要技术改进,它用于减轻运行应用程序的系统开销.

中文名

.Net Remoting

作    用

减轻运行应用程序的系统开销

目录

  1. 1 介绍
  2. 2 .NET Remoting的原理
  1. ▪ 1.NET Remoting的体系结构
  2. ▪ 2..NET Remoting的扩展
  1. 3 .NET Remoting的分布式应用

介绍

编辑

从结构上看,.NETRemoting对象非常适合通过网络访问资源,而又无需处理由基于SOAP的Web Service所带来的难题。对于内部网应用程序而言,Web服务器和SOAP协议的使用并不是总有效的。当传输的数据的量很大时, DCOM协议系统开销就太大了。在过去开发人员通常使用DCOM编写程序。有了DCOM,我们习惯于调用均等在服务器上的对象的方法,.Net Remoting就是DCOM的替代者。与DCOM相比,.Net Remo-ting也可以在Internet解决方案中。在Internet解决方案中,DCOM显得不太灵活和效率不高。.Net Remoting.不需要创建存根程序和骨架文件,使用起来比Java的RMI简单而且为处理局域网甚至互联网范围内的资源提供了一个绝佳的方法,使用范围比JAVA的RMI更广泛。使用.Net Remoting框架技术可以匹配和扩展体系结构的每一个部分,不仅增加了它的灵活性,也大大扩展了它的应用范围。.NET Remoting几乎适合于所有涉及远程的工作 [1]  。

.NET Remoting的原理

编辑

1.NET Remoting的体系结构

NETRemoting的体系结构如图1所示。

图1图1

在图1的客户端应用程序域和服务端应用程序域的分界线构成了 .NET Remoting 的边界。在服务端即服务端应用程序域由传输通道,序列化格式程序和Server Object组成(运行在服务器上的对象称为远程对象)。在客户端即客户应用程序域如图1所示由Client Object、代理、传输通道、序列化格式程序组成。下面分述几个重要的概念。

(1)应用程序域 可以将应用程序域看作是一个逻辑进程。在传统意义上,进程通常被用作隔离的分界线,也就是说,在一进程中运行的应用程序不能访问和破坏另一个进程,应用域就成为进程中新的安全分界线。

(2)客户代理 客户代理分为透明代理和真实代理。其中,透明代理是远程对象的精确副本,它具有远程对象所具有的可用的方法调用,它截取了所有对远程对象的直接方法调用,并将它们传递给真实代理。真实代理是具体的处理,它接受透明代理创建的消息并将其发送到.NET Remoting基础设施用于最终传递给远程对象。

图2图2

(3)传输通道 .NET Remoting通过通道穿越.NET Remoting边界传输序列化的消息对象,它由格式化接收器、通道接收器、传输接收器组成。其内部结构如图2所示。

常用的是TCP通道和HTTP通道。TCP通道主要用Internet,HTTP通道主要可以和SOAP协议结合用于Internet,可以穿越防火墙。并且还可以根据需要定制通道,如安全加密通道。

(4)对象激活 对象激活分为服务器端激活和客户端激活。服务器端激活分为Singleton和SingleCall模式。 .NET Remoting将服务器端激活类型称为众所周知的对象类型,服务器在应用程序激活对象实例之前会在一个众所周知的统一资源标识符(URI)上发布这个类型。在处理客户端激活时,与处理服务器端激活类型相比,.NET Remoting基础设施激活每个对象实例的时候会给每个客户端激活的类型指派一个URI。

2..NET Remoting的扩展

.NET Remoting具有良好的扩展性,可以根据需要替代真实代理对象、添加接收器对象、替代格式标识符和通道等。介绍通道的定制,具体如下:

(1)创建客户端通道类 客户端通道由三个分别继承IchannelSender,IclientChannelSinkPvovider,IchannelSink的类构成。Public class SDC ClientChannel:IchannelSender{...},…

(2)创建服务器端通道类 服务器端包含两个类,它们分别继承IchannelReceiver和IserverChannelSink Public class SDC ServerChannel:IchannelReceive{...},…

(3)创建名为SDC的类 此类存放服务器和客户端通道所共享的功能。

(4)创建结合了服务器端和客户端类 两者功能的主通道类:Public class SDC Channel: Ichannel, IchannelReceiver{...}, …

.NET Remoting的分布式应用

编辑

在众多的分布式体系应用中,Peer-to-Peer(简称P2P)是近来研究的热点。在这种模型下,每个客户端同时也是一个服务器。此模型与C/S模型主要区别是:应用程序配置Remoting以侦听客户端请求,并通过Remoting来调用类。在大多数P2P应用程序中,给定的对等端同时连接到多个其他的对等端。这就意味着不能使用Remoting静态配置。为此,我们将不在Remoting中注册远程类,而是使用.NETFramework中的一种特殊方法来创建远程对象即Activator. GetObject,它接受两个参数:第一个是要创建的对象类型;第二个是要在其上创建对象的Remoting主机的URL。编码如下:

1

2

3

4

5

6

7

8

9

10

RemotingConfiguration.ApplicationName=″Peer APP″

 ∥设置应用程序名称

 mChannel= NewTcpChannel(CInt(Port.Text))∥创建通道

 ChannelServices.RegisterChannel(mChannel)

 RemotingConfiguration. RegisterWellKnownServiceType(GetType(Listener),″Listener″, WellKnownObjectMode.SingleCall)∥注册远程对象

 这样其他的对等端就可以通过Remoting来使用Listener类,当对等端在侦听时,其他对等端就可以连接到它并与Listener对象进行交互:

 Dim listener As Listener

 … …

 listener= Activator.GetObject(GetType(Listener),url.ToString)

 … …

参考资料

  • 1.  基于.NET Remoting的分布式系统实现   .万方[引用日期2018-06-23]

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/436804.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

python多重赋值技巧_python教程12课:多元赋值、多重赋值、运算符以及判断字符串类型...

# 多元赋值:# x,y,z 和 1,2,‘String是两个元组,只不过元组的 () 被省略掉了x, y ,z 1, 2, Stringprint(x, y, z)(x, y ,z) (3, 4, String)print(x,y,z)# 一般用在交换变量值#交换变量值常规思路x 10,y 20z 30x ,y, z y,z,xprint(x,y,z)#使用多元赋值…

【转】关于CLR内存管理一些深层次的讨论[下篇]

《上篇》中我们主要讨论的是程序集(Assembly)和应用程序域(AppDomain)的话题,着重介绍了两个不同的程序集加载方式——独占方式和共享方式(中立域方式);以及基于进程范围内的字符串驻…

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第一节 理解堆与栈

理解堆与栈 导航 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第一节 理解堆与栈 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第二节 栈基本工作原理 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第三节 栈与堆,值类型与引用类型 深入浅出图…

bi 存储过程方案_BI 系统中容易被忽视的数据源功能

BI 系统中容易被忽视的数据源功能用户在选购 BI 解决方案的时候,常常会更关注界面环节的功能指标,比如美观性、操作的流畅性、移动端支持等等。毕竟,BI 是要给业务人员使用的,这些看得见的内容一般不容易被遗漏。然而,…

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第二节 栈基本工作原理

栈基本工作原理 导航 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第一节 理解堆与栈 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第二节 栈基本工作原理 深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第三节 栈与堆,值类型与引用类型 深入浅…

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第三节 栈与堆,值类型与引用类型

前言 虽然在.Net Framework 中我们不必考虑内在管理和垃圾回收(GC),但是为了优化应用程序性能我们始终需要了解内存管理和垃圾回收(GC)。另外,了解内存管理可以帮助我们理解在每一个程序中定义的每一个变量是怎样工作的。 简介 本文将介绍值类型与引用类…

【转】.net框架读书笔记---CLR内存管理\垃圾收集(一)

一、垃圾收集平台基本原理解析 在C#中程序访问一个资源需要以下步骤: 调用中间语言(IL)中的newobj指令,为表示某个特定资源的类型实例分配一定的内存空间。初始化上一步所得的内存,设置资源的初始状态,从而…

【转】.net框架读书笔记---CLR内存管理\垃圾收集(七)

编程控制垃圾收集器 System.GC类型为应用程序提供了直接控制垃圾收集器的一些方法,可以通过GC.MaxGeneration来查询托管堆支持的最大代龄,目前为2。 通过下面方法执行垃圾收集器 GC.Collect(int);传递代龄,传递0,收集0代&#xff…

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第四节 参数传递对堆栈的影响 1

前言 虽然在.Net Framework 中我们不必考虑内在管理和垃圾回收(GC),但是为了优化应用程序性能我们始终需要了解内存管理和垃圾回收(GC)。另外,了解内存管理可以帮助我们理解在每一个程序中定义的每一个变量是怎样工作的。 简介 这篇文章我们将介绍一些方…

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第四节 参数传递对堆栈的影响 2

前言 虽然在.Net Framework 中我们不必考虑内在管理和垃圾回收(GC),但是为了优化应用程序性能我们始终需要了解内存管理和垃圾回收(GC)。另外,了解内存管理可以帮助我们理解在每一个程序中定义的每一个变量是怎样工作的。 简介 继续上篇未完成的“参数传…

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第五节 引用类型复制问题及用克隆接口ICloneable修复

前言 虽然在.Net Framework 中我们不必考虑内在管理和垃圾回收(GC),但是为了优化应用程序性能我们始终需要了解内存管理和垃圾回收(GC)。另外,了解内存管理可以帮助我们理解在每一个程序中定义的每一个变量是怎样工作的。 简介 这一节我们将介绍引用类型…

linux virt java_Linux下Java环境安装

本节主要讲解Linux(Centos 6.5)下Java环境的安装1. 卸载机器上默认安装的JDK在Linux环境下一般会默认安装jdk,为了自己项目的开发部署,一般情况要重新装jdk,而且自己装的Jdk相对来说易控制版本,稳定性更高。所以以下是我卸载预装J…

【转】深入浅出图解C#堆与栈 C# Heap(ing) VS Stack(ing) 第六节 理解垃圾回收GC,提搞程序性能****

前言 虽然在.Net Framework 中我们不必考虑内在管理和垃圾回收(GC),但是为了优化应用程序性能我们始终需要了解内存管理和垃圾回收(GC)。另外,了解内存管理可以帮助我们理解在每一个程序中定义的每一个变量是怎样工作的。 简介 这一节我们将介绍垃圾回…

【转】分布式事务的常见解决方案

一、事务起步 1. 什么是事务 事务这种东西大家都耳熟能详了,通常指由一组操作组成的一个工作单元,这一整个组合要么全部成功,要么全部失败。 2. 本地事务 在计算机系统中,更多的是通过关系型数据库来控制事务,这是…

java s.charat_Java中s.charAt(index)用于提取字符串s中的特定字符操作

charAt(int index)方法是一个能够用来检索特定索引下的字符的String实例的方法.charAt()方法返回指定索引位置的char值。索引范围为0~length()-1.如: str.charAt(0)检索str中的第一个字符,str.charAt(str.length()-1)检索最后一个字符.警告:在字符串s中越界访问字符…

【转】.NET框架简介

.NET 框架是由微软开发的软件开发平台,其最主要的两个组成部分是公共语言运行时 (CLR) 和框架类库 (FCL),基础类库 (BCL)是框架类库的一个子集。 .NET 框架简介 下图展示了 .NET 框架的主要结构。 其中,最下层的无疑就是操作系统了。 在 …

java比赛题目_【蓝桥杯2016第七届比赛题目】JAVA A组

1 煤球数目有一堆煤球,堆成三角棱锥形。具体:第一层放1个,第二层3个(排列成三角形),第三层6个(排列成三角形),第四层10个(排列成三角形),....如果一共有100层,共有多少个煤球?请填表…

【转】C#技术漫谈之垃圾回收机制(GC)

摘要:今天我们漫谈C#中的垃圾回收机制,本文将从垃圾回收机制的原理讲起,希望对大家有所帮助。 GC的前世与今生 虽然本文是以.NET作为目标来讲述GC,但是GC的概念并非才诞生不久。早在1958年,由鼎鼎大名的图林奖得主John…

【转】git hub 使用小结

【转自:https://blog.csdn.net/yj310873325/article/details/79255134】 1.创建账号: https://github.com/ 2.下载客户端:https://git-scm.com/download 这是命令行模式,用着比较舒服,不是github的客户端,一路默认安…

【转】细说.NET 中的多线程 (一 概念)

为什么使用多线程 1.使用户界面能够及时响应用户的输入 当某个应用程序在进行大量运算时候,为了保证应用程序能够随时响应客户的输入,这个时候我们往往需要让大量运算和响应用户输入这两个行为在不同的线程中进行。 2.效率原因 应用程序经常需要等待一…