c# Remoting分布式开发

2024-01-11 07:48

本文主要是介绍c# Remoting分布式开发,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

.NET c# Remoting分布式开发

  一、基础概念

  Remoting是采用分布式进行编程的一种技术,主要用于管理跨应用程序域的同步和异步RPC 会话。在默认情况下,Remoting可从使用 HTTP 或 TCP 协议进行信息通讯,并使用 XML 编码的 SOAP 或二进制消息格式进行数据交换。.NET Remoting 提供了非常灵活和可扩展的编程框架,并且可以管理对象的状态。Remoting跟Web服务不同,它并不依赖于IIS,用户可以自己开发 (Development)并部署(Dispose)宿主服务器,只需要服务器支持Framework。

  二、Remoting的特点

 

  Remoting可以灵活的定义其所基于的协议,比如http,tcp等。在使用TCP/IP的时候,Remoting能发挥更高的效率,其性能接近于DCOM。

  Remoting一般需要通过一个应用程序或是Windows服务来承载,也可以使用iis部署。

  Remoting必须要在一个支持Framework的开发环境下进行开发,无论客户端跟服务器端都必须支持Framework。

  Remoting 支持许多状态管理选项,并且可能与来自同一个用户的多个调用相关或不相关,这取决于您选择的对象生命周期架构。

  三、利用Remoting实现分布式开发的优点

  • 容错性

  容错性是指一个系统在出现故障时,系统应当能及时恢复。利用Remoting实现分布式应用开发可以建立容错软件系统,当某个功能发生错误时,不会影响整体系统的工作。使系统能够及时维护及更新。

  • 可扩展性

  可扩展性是指系统可以利用性能上的递增处理日益增加的负载量。利用 Remoting实现分布式开发,可以将最重要的核心功能模块放置于性能强大的几台主机上,把其他的功能放置于功能稍差的客户端机上,随着客户的增加而加大客户端主机的服务。这样做可以减少开发成本,提高主体性能。

  • 易于管理

  一个大型计算机管理系统是非常复杂的,可能涉及的是异地机器之间的代码调节。利用Remoting实现分布式开发,可以把核心的功能代码移植到中央服务器,把页面层,UI层等功能于客户端实现。这样系统的性能调节,代码升级都可以在中央服务器里综合实现,而忽略对客户端的影响。

  四、Remoting体系结构

  下面详细介绍一下Remoting的体系结构,如下图。

  在客户发送请求时可以通过Activator.GetObject()和 Activator.CreateInstance()返回一个透明代理对象。实际上透明代理就像一个远程对象,它执行远程对象的所有公共方法,这些方法调用真实对象的Invoke()方法,传送包含方法调用的消息。

  当消息进入Channel通道后,就会经过接收器处理。接收器包含格式接收器、通道接收器和传输接收器,其中格式接收器和传输接收器是必要的。首先格式接收器会使用SoapFormatter或 BinaryFormatter的方式对传输的对象进行序列化,如果用户设定了通道接收器,系统将会对其进行对应处理,最后把信息送到传输接收器,对应设定TCP或HTTP传输方式加入传输接收器头。当信息发送到服务器,服务器将会根据传输接收器头对信息进行处理,然后在格式化接收器中对信息进行反序列化,最后通过真实代理处理远程对象。至于通道接收器的处理方式,将在后几章为大家进一步地介绍。


  五、简单实例

  说了这么多,下面就以一个简单的例子说明一下Remoting的开发过程吧。

  首先建立一个Model.dll,注意因为对象要进行序列化转化,必须对其加上Serializable特性!

 

代码using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;

namespace Model
{
[Serializable]
publicclass Person
{
publicint ID
{
get;
set;
}

public String Name
{
get;
set;
}

publicint Age
{
get;
set;
}
}
}

  然后建立一个可远程调用的对象,注意远程对象必须继承MarshalByRefObject

代码using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Runtime.Serialization.Formatters.Binary;
using System.IO;
using Model;

namespace Manager
{
//类必须继承了MarshalByRefObject,才能进行远程调用
publicclass PersonManager:MarshalByRefObject
{
public List<Person> GetList()
{
List<Person> personList =new List<Person>();
FileStream stream =new FileStream("DataSource.sour", FileMode.Open, FileAccess.Read); //在服务器文件里面获取虚拟数据
BinaryFormatter formatter =new BinaryFormatter();
personList=(List<Person>)formatter.Deserialize(stream); //对虚拟数据进行反序列化获取集合
return personList;
}
}
}

  在一个应用程序中加载服务器端,服务器端的配置有两种试,一是直接写在代码里面。首先建立服务传送方式,可以选择用TcpServerChannel,也可使用HttpChannel,前者有着更高的效率。然后在 ChannelService注册此传输通道,最后通过RemotingConfiguration的 RegisterWellKnownServiceType方法注册远程对象。

  注意WellKonwnObjectMode可选择为SingleTon或者SingleCall,前者使用单体模式,每个客户端进行访问都会使用同一个远程对象。后者会为每个请求建立一个远程对象。在这个例子里面我们使用SingleTon单体模式。

代码using System.Runtime.Remoting;
using System.Runtime.Remoting.Channels;
using System.Runtime.Remoting.Channels.Tcp;
using Model;
using Manager;

namespace Server
{
class Program
{
staticvoid Main(string[] args)
{
//建立服务传输方式,可选择TCP或者HTTP,前者更能发挥高效性
TcpServerChannel channel =new TcpServerChannel(8089);
//注册通道
ChannelServices.RegisterChannel(channel, false);
//添加可调用的远程对象,WellKonwnObjectMode可选择为SingleTon或者SingleCall
RemotingConfiguration.RegisterWellKnownServiceType(typeof(PersonManager), "PersonTcp", WellKnownObjectMode.Singleton);
Console.ReadKey();
}
}
}

  第二,可以在config文件里面实现服务器的配置,其效果与代码实现的相同。

config<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<system.runtime.remoting>
<application name="Server">
<service>
//定义传送模式,远程对象类,Uri路径
<wellknown mode="Singleton" type="Manager.PersonManager,Manager" objectUri="PersonUri"/>
</service>
<channels>
//定义传送通道,传送方式和接口
<channel ref="tcp" port="8089"/>
</channels>
</application>
</system.runtime.remoting>
</configuration>

  最后在客户端对远程对象进行调用

代码using System.Runtime.Remoting.Channels;
using System.Runtime.Remoting.Channels.Tcp;
using Model;
using Manager;

namespace Client
{
class Program
{
staticvoid Main(string[] args)
{
//确立通道传送方式
ChannelServices.RegisterChannel(new TcpClientChannel(),false);
//使用Activator.GetObject()或者Activator.CreateInstance()方法建立透明代理,控制远程对象
PersonManager personManager = (PersonManager)Activator.GetObject(typeof(PersonManager), "tcp://localhost:8089/PersonUri");
//获取远程数据
List<Person> personList = personManager.GetList();
Console.Write(personList.Count);
Console.ReadKey();
}
}
}

  六、总结

  上面已经为大家介绍了一个简单的Remoting开发实例。利用 Remoting实现分布式开发,可以对远程对象的生命周期进行管理,利用     HttpChannel,HttpServerChannel,HttpServerTransportSink,HttpClientChannel,

HttpClientTransportSinkProvider,HttpClientTransportSink等对象控制服务器端和客户端的通道,使用代理、消息接收器与通道接收器对信息进行管理。

这篇关于c# Remoting分布式开发的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/593633

相关文章

C#文件复制异常:"未能找到文件"的解决方案与预防措施

《C#文件复制异常:未能找到文件的解决方案与预防措施》在C#开发中,文件操作是基础中的基础,但有时最基础的File.Copy()方法也会抛出令人困惑的异常,当targetFilePath设置为D:2... 目录一个看似简单的文件操作问题问题重现与错误分析错误代码示例错误信息根本原因分析全面解决方案1. 确保

基于C#实现PDF转图片的详细教程

《基于C#实现PDF转图片的详细教程》在数字化办公场景中,PDF文件的可视化处理需求日益增长,本文将围绕Spire.PDFfor.NET这一工具,详解如何通过C#将PDF转换为JPG、PNG等主流图片... 目录引言一、组件部署二、快速入门:PDF 转图片的核心 C# 代码三、分辨率设置 - 清晰度的决定因

C# LiteDB处理时间序列数据的高性能解决方案

《C#LiteDB处理时间序列数据的高性能解决方案》LiteDB作为.NET生态下的轻量级嵌入式NoSQL数据库,一直是时间序列处理的优选方案,本文将为大家大家简单介绍一下LiteDB处理时间序列数... 目录为什么选择LiteDB处理时间序列数据第一章:LiteDB时间序列数据模型设计1.1 核心设计原则

Python实战之SEO优化自动化工具开发指南

《Python实战之SEO优化自动化工具开发指南》在数字化营销时代,搜索引擎优化(SEO)已成为网站获取流量的重要手段,本文将带您使用Python开发一套完整的SEO自动化工具,需要的可以了解下... 目录前言项目概述技术栈选择核心模块实现1. 关键词研究模块2. 网站技术seo检测模块3. 内容优化分析模

Redis实现分布式锁全过程

《Redis实现分布式锁全过程》文章介绍Redis实现分布式锁的方法,包括使用SETNX和EXPIRE命令确保互斥性与防死锁,Redisson客户端提供的便捷接口,以及Redlock算法通过多节点共识... 目录Redis实现分布式锁1. 分布式锁的基本原理2. 使用 Redis 实现分布式锁2.1 获取锁

基于Java开发一个极简版敏感词检测工具

《基于Java开发一个极简版敏感词检测工具》这篇文章主要为大家详细介绍了如何基于Java开发一个极简版敏感词检测工具,文中的示例代码简洁易懂,感兴趣的小伙伴可以跟随小编一起学习一下... 目录你是否还在为敏感词检测头疼一、极简版Java敏感词检测工具的3大核心优势1.1 优势1:DFA算法驱动,效率提升10

C#高效实现Word文档内容查找与替换的6种方法

《C#高效实现Word文档内容查找与替换的6种方法》在日常文档处理工作中,尤其是面对大型Word文档时,手动查找、替换文本往往既耗时又容易出错,本文整理了C#查找与替换Word内容的6种方法,大家可以... 目录环境准备方法一:查找文本并替换为新文本方法二:使用正则表达式查找并替换文本方法三:将文本替换为图

C#使用Spire.XLS快速生成多表格Excel文件

《C#使用Spire.XLS快速生成多表格Excel文件》在日常开发中,我们经常需要将业务数据导出为结构清晰的Excel文件,本文将手把手教你使用Spire.XLS这个强大的.NET组件,只需几行C#... 目录一、Spire.XLS核心优势清单1.1 性能碾压:从3秒到0.5秒的质变1.2 批量操作的优雅

C#和Unity中的中介者模式使用方式

《C#和Unity中的中介者模式使用方式》中介者模式通过中介者封装对象交互,降低耦合度,集中控制逻辑,适用于复杂系统组件交互场景,C#中可用事件、委托或MediatR实现,提升可维护性与灵活性... 目录C#中的中介者模式详解一、中介者模式的基本概念1. 定义2. 组成要素3. 模式结构二、中介者模式的特点

C#中SortedSet的具体使用

《C#中SortedSet的具体使用》SortedSet是.NETFramework4.0引入的一个泛型集合类,它实现了一个自动排序的集合,内部使用红黑树数据结构来维护元素的有序性,下面就来介绍一下如... 目录基础概念主要特性创建和初始化基本创建方式自定义比较器基本操作添加和删除元素查询操作范围查询集合运