【.NetRemoting】2015.09.16
【分布式应用程序】
应用程序分布在不同计算机上,通过网络来共同完成一项任务
C/S架构[模式]
【互操作性,Interoperability】又称【互用性】
是指不同的计算机系统、网络、操作系统和应用程序一起工作并共享信息的能力。

【.Net网络编程技术】
WCF,Web Service,Remoting,Socket

【应用程序域,AppDomian,Application Domain】
1.【缘由】
【1】.Net程序集需要运行在托管环境中
【2】操作系统并不了解托管代码
【3】需要有一个中介,既能为程序集提供托管环境,又能运行在非托管的操作系统的进程之内==>AppDomian;
【4】所有.Net程序集都运行在AppDomain
2.
【应用程序域是运行为它加载的程序集访问.Net CLR提供的服务的】
【.Net提供的运行时服务】
托管堆,GC,JIT编译器,程序集加载器等

3.
【1】可以将AppDomian类比为一个轻量级的进程,
【2】一个线程可以有多个AppDomian
【3】【默认的应用程序域】+【其他的应用程序域】
【4】应用程序域提供与进程类似的隔离性

4.创建AppDomian的优势
【进程创建一个AppDomian比操作系统创建一个进程的开销要小】

5.应用程序域的基本操作
【1】获取当前运行代码/程序集所在的AppDomian
AppDomian.CurrentDomain;
Thread.GetDomain();
【2】获取应用程序域的名称
FriendlyName
【3】创建新的应用程序域
AppDomian.CreareDomain("AppDomianName");
【4】在应用程序域中创建对象
【A】使用CreateInstanceAndUnWrap()方法;
【B】使用CreateInstance()方法创建对象

【5】判断是否是默认AppDomian
IsDefaultAppDomain();

【默认的程序域】
【1】线程创建时即被创建
【2】无法卸载,与所在的进程同生同灭

【在默认程序域中创建对象】

【在新建的应用程序域中创建对象】
对象从另外一个AppDomian中传递给本地AppDomian
需要对传递的对象进行序列化

【思考】
如何使用应用程序域动态的加载一个程序集

【代理,Proxy】
【1】在应用程序域中创建对象和使用构造函数创建对象的区别?
【构造函数】
在堆中直接创建一个对象,由变量名直接引用到对象
【在应用程序域中创建对象】
【1】在应用程序域中创建对象
【2】将对象序列化后封送【Marshaling】到本地/客户端应用程序域==>【远程对象】
【3】客户端应用程序域重新创建对象,还原对象状态,==>创建对象代理【Proxy】,【代理对象】
【4】客户端通过代理对象访问远程对象

【Proxy】提供了和远程对象完全相同的接口。
客户端基于远程对象的类型元数据来创建代理,因此客户端必须包含远程对象的类型元数据
【元数据】
类型得接口,包含名称,签名,不包括实现代码

【代理对象】newAppDomain中创建的对象
【远程对象】客户端应用程序域中创建的对象

【封送,Marshal】==>2中方式,传值,传引用
【传值封送,Marshal By Value】将对象传递到客户端
【传引用封送,Marshal By reference】将对象依旧留在远程AppDomian中,创建代理,通过代理访问远程对象
【传引用封送的方式】【有三种方式】
【1】客户端激活【Client activated】==>客户端激活对象,CAO,Client activated Object
【2】服务端激活Singleton【Service activated Singleton】
【3】服务端激活SingleCall【Service activated SingleCall】

【传引用封送】==>MBR对象
【MarshalByRefObject对象】
需要封送的对象必须要继承MBR类
【当一个对象继承自MBR之后,标志着该对象永远无法离开他所在的应用程序域】

【传引用封送和传值封送的优势】
对象大时候,传值封送的效率要低,传值封送需要将对象序列化,将整个对象封送到客户端,增加了网络负担。。。

【Remoting】
跨应用程序域的访问都属于Remoting。
【无论AppDomian是在同一个进程内,还是同一个主机不同进程内的AppDomian,还是不同计算机的进程】
【客户端】
发出请求的一端
【服务端】
提供类型的一端

【一个典型的Remoting程序】
【1】【服务程序集,提供服务的类型】
==>这些类型通常继承自MBR,[传引用封送的优势]
【2】【服务端应用程序】==>【宿主应用程序域】
==>提供服务程序集运行的环境【IIS,Windows服务,控制台程序,winform窗体程序等等】
【3】【客户端应用程序域】
==>向宿主应用程序域发出请求的应用程序域

【.Net Remoting-1】的更多相关文章

  1. 【开源】简单4步搞定QQ登录,无需什么代码功底【无语言界限】

    说17号发超简单的教程就17号,qq核审通过后就封装了这个,现在放出来~~ 这个是我封装的一个开源项目:https://github.com/dunitian/LoTQQLogin ————————— ...

  2. 【夯实PHP基础】PHP数组,字符串,对象等基础面面观

    本文地址 分享提纲 1.数组篇 2.字符创篇 3.函数篇 4.面向对象篇 5.其他篇 /*************************** 一.数组篇 Begin***************** ...

  3. 【Java学习系列】第3课--Java 高级教程

    本文地址 可以拜读: 从零开始学 Java 分享提纲: 1. Java数据结构 2. Java 集合框架 3. Java泛型 4. Java序列化 5. Java网络编程 6. Java发送Email ...

  4. 【夯实PHP基础】nginx php-fpm 输出php错误日志

    本文地址 原文地址 分享提纲: 1.概述 2.解决办法(解决nginx下php-fpm不记录php错误日志) 1. 概述 nginx是一个web服务器,因此nginx的access日志只有对访问页面的 ...

  5. 分布式学习系列【dubbo入门实践】

    分布式学习系列[dubbo入门实践] dubbo架构 组成部分:provider,consumer,registry,monitor: provider,consumer注册,订阅类似于消息队列的注册 ...

  6. 【第三篇】ASP.NET MVC快速入门之安全策略(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

  7. 【番外篇】ASP.NET MVC快速入门之免费jQuery控件库(MVC5+EF6)

    目录 [第一篇]ASP.NET MVC快速入门之数据库操作(MVC5+EF6) [第二篇]ASP.NET MVC快速入门之数据注解(MVC5+EF6) [第三篇]ASP.NET MVC快速入门之安全策 ...

  8. 【初码干货】在Window Server 2016中使用Web Deploy方式发布.NET Web应用的重新梳理

    在学习和工作的过程中,发现很多同事.朋友,在做.NET Web应用发布的时候,依然在走 生成-复制到服务器 这样的方式,稍微高级一点的,就是先发布到本地,再上传到服务器 这种方式不仅效率低下,而且不易 ...

  9. 【夯实PHP基础】PHP的反射机制

    本文地址 分享提纲: 1. 介绍 2. 具体例子 2.1 创建Persion类 2.2 反射过程 2.3 反射后使用 1. 介绍 -- PHP5添加了一项新的功能:Reflection.这个功能使得p ...

  10. 【Java学习系列】第2课--Java语法及面向对象

    本文地址 分享提纲: 1. Java程序特点 1.1 基本语法 1.2 字符串 1.3 变量 1.4 Java数组 1.5 Java枚举 1.6 Java修饰符 1.7 Java编译制定在制定目录 2 ...

随机推荐

  1. C++中的虚函数

    代码: #include <iostream> #include <cstring> using namespace std; class Base{ public: virt ...

  2. 清空文本框SetDlgItemText(IDC_TXTXT,NULL);

    清空文本框 SetDlgItemText(IDC_TXTXT,NULL);

  3. jade的基本语法

    - for (var i=0;i<3;i++) li scnu-learn //这里的=,默认会转义内容 p= "Welcome scnu <strong>good< ...

  4. 关于JS中的this关键字

    在学习js时,应该先了解下this关键字,关于js中的this关键字和其他的面向对象语言中的this是不同的,比如在java中,this指的的是当前对象,而在js中,w3c是这样规定的: 关键字 th ...

  5. 最大公约数(gcd):Euclid算法证明

    1个常识: 如果 a≥b 并且 b≤a,那么 a=b. 2个前提: 1)只在非负整数范围内讨论两个数 m 和 n 的最大公约数,即 m, n ∈ N. 2)0可以被任何数整除,但是0不能整除任何数,即 ...

  6. (转)CentOS搭建Nagios监控

    A.Nagios服务端1.安装软件包 yum install -y httpd 2.下载nagios wget http://syslab.comsenz.com/downloads/linux/na ...

  7. 从头到尾彻底理解KMP(2014年8月22日版)

    http://blog.csdn.net/v_july_v/article/details/7041827

  8. c#提出中文首字母

           ; i < len; i++)             {                 myStr += getSpell(strText.Substring(i, ));   ...

  9. hdu1067-Gap(bfs+哈希)

    Let's play a card game called Gap. You have 28 cards labeled with two-digit numbers. The first digit ...

  10. 减少GC开销的5个编码技巧

    在这篇文章中,我们来了解一下让代码变得高效的五种技巧,这些技巧可以使我们的垃圾收集器(GC)在分配内存以及释放内存上面,占用更少的CPU时间,减少GC的开销.当内存被回收的时候,GC处理很长时间经常会 ...