天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

回顧.NET Remoting分布式開發(fā)

  記得在下第一次接觸.NET Remoting分布式開發(fā)是在2003年,那時候是Framework1.0初次亮相之時,Remoting分布式開發(fā)是Framework1.0其中一個亮點。經(jīng)過多年的發(fā)展,在2005年,WCF隨著Framework2.0首先亮相。WCF是結(jié)合Remoting,Web服務(wù),TCP/IP套接字,MSMQ信息,P2P,WSE等多方通訊的混合體。

  隨著WCF的出現(xiàn)是否意昧著Remoting即將沒落,答案是否定的。因為Remoting有其獨到之處,在通訊效率,信息交換,安全性等多方面都有其特點,所以在企業(yè)內(nèi)部系統(tǒng)的信息化交換層的開發(fā)當(dāng)中,很多時候會使用Remoting進行開發(fā),在下面幾章為大家回顧一下Remoting的開發(fā)。

  一、基礎(chǔ)概念

  Remoting是采用分布式進行編程的一種技術(shù),主要用于管理跨應(yīng)用程序域的同步和異步RPC 會話。在默認(rèn)情況下,Remoting可從使用 HTTP 或 TCP 協(xié)議進行信息通訊,并使用 XML 編碼的 SOAP 或二進制消息格式進行數(shù)據(jù)交換。.NET Remoting 提供了非常靈活和可擴展的編程框架,并且可以管理對象的狀態(tài)。Remoting跟Web服務(wù)不同,它并不依賴于IIS,用戶可以自己開發(fā)(Development)并部署(Dispose)宿主服務(wù)器,只需要服務(wù)器支持Framework。

  二、Remoting的特點

  Remoting可以靈活的定義其所基于的協(xié)議,比如http,tcp等。在使用TCP/IP的時候,Remoting能發(fā)揮更高的效率,其性能接近于DCOM。

  Remoting一般需要通過一個應(yīng)用程序或是Windows服務(wù)來承載,也可以使用iis部署。

  Remoting必須要在一個支持Framework的開發(fā)環(huán)境下進行開發(fā),無論客戶端跟服務(wù)器端都必須支持Framework。

  Remoting 支持許多狀態(tài)管理選項,并且可能與來自同一個用戶的多個調(diào)用相關(guān)或不相關(guān),這取決于您選擇的對象生命周期架構(gòu)。

  三、利用Remoting實現(xiàn)分布式開發(fā)的優(yōu)點

  • 容錯性

  容錯性是指一個系統(tǒng)在出現(xiàn)故障時,系統(tǒng)應(yīng)當(dāng)能及時恢復(fù)。利用Remoting實現(xiàn)分布式應(yīng)用開發(fā)可以建立容錯軟件系統(tǒng),當(dāng)某個功能發(fā)生錯誤時,不會影響整體系統(tǒng)的工作。使系統(tǒng)能夠及時維護及更新。

    • 可擴展性

      可擴展性是指系統(tǒng)可以利用性能上的遞增處理日益增加的負(fù)載量。利用Remoting實現(xiàn)分布式開發(fā),可以將最重要的核心功能模塊放置于性能強大的幾臺主機上,把其他的功能放置于功能稍差的客戶端機上,隨著客戶的增加而加大客戶端主機的服務(wù)。這樣做可以減少開發(fā)成本,提高主體性能。

    • 易于管理

      一個大型計算機管理系統(tǒng)是非常復(fù)雜的,可能涉及的是異地機器之間的代碼調(diào)節(jié)。利用Remoting實現(xiàn)分布式開發(fā),可以把核心的功能代碼移植到中央服務(wù)器,把頁面層,UI層等功能于客戶端實現(xiàn)。這樣系統(tǒng)的性能調(diào)節(jié),代碼升級都可以在中央服務(wù)器里綜合實現(xiàn),而忽略對客戶端的影響。

      四、Remoting體系結(jié)構(gòu)

      下面詳細(xì)介紹一下Remoting的體系結(jié)構(gòu),如下圖。

      在客戶發(fā)送請求時可以通過Activator.GetObject()和Activator.CreateInstance()返回一個透明代理對象。實際上透明代理就像一個遠(yuǎn)程對象,它執(zhí)行遠(yuǎn)程對象的所有公共方法,這些方法調(diào)用真實對象的Invoke()方法,傳送包含方法調(diào)用的消息。

      當(dāng)消息進入Channel通道后,就會經(jīng)過接收器處理。接收器包含格式接收器、通道接收器和傳輸接收器,其中格式接收器和傳輸接收器是必要的。首先格式接收器會使用SoapFormatter或BinaryFormatter的方式對傳輸?shù)膶ο筮M行序列化,如果用戶設(shè)定了通道接收器,系統(tǒng)將會對其進行對應(yīng)處理,最后把信息送到傳輸接收器,對應(yīng)設(shè)定TCP或HTTP傳輸方式加入傳輸接收器頭。當(dāng)信息發(fā)送到服務(wù)器服務(wù)器將會根據(jù)傳輸接收器頭對信息進行處理,然后在格式化接收器中對信息進行反序列化,最后通過真實代理處理遠(yuǎn)程對象。至于通道接收器的處理方式,將在后幾章為大家進一步地介紹。


      五、簡單實例

      說了這么多,下面就以一個簡單的例子說明一下Remoting的開發(fā)過程吧。

      首先建立一個Model.dll,注意因為對象要進行序列化轉(zhuǎn)化,必須對其加上Serializable特性!

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

    namespace Model
    {
    [Serializable]
    public class Person
    {
    public int ID
    {
    get;
    set;
    }

    public String Name
    {
    get;
    set;
    }

    public int Age
    {
    get;
    set;
    }
    }
    }

    NET技術(shù)回顧.NET Remoting分布式開發(fā),轉(zhuǎn)載需保留來源!

    鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請第一時間聯(lián)系我們修改或刪除,多謝。

    主站蜘蛛池模板: 高hbl双性浪荡古代 高h 大尺度纯肉 np快穿 | 粉嫩国产14xxxxx0000 | 草莓国产视频免费观看 | 成人毛片100部免费看 | 99视频在线观看免费 | 草莓视频免费在线观看 | 久久re热在线视频精69 | 翁公与小莹在客厅激情 | 免费国产麻豆传 | 亚洲色偷偷偷网站色偷一区人人藻 | 夜夜澡人人爽人人喊_欧美 夜夜骑夜夜欢 | 处初女处夜情视频在线播放 | 在线免费公开视频 | 国产做国产爱免费视频 | 小骚妇BBBXXX| 2020最新无码国产在线视频 | 视频一区二区中文字幕 | 嫩草www视频在线观看高清 | 人与人特黄一级 | 亚洲视频999 | aaa级黄影片 | 色婷婷国产精品视频一区二区 | 国产白丝精品爽爽久久蜜臀 | 亚洲AV国产精品无码精 | 吃奶吸咪咪动态图 | xxxxx俄罗斯| 混乱家庭电影完整版在线看 | 日本久久久免费高清 | 天海翼精品久久中文字幕 | 婷婷亚洲五月色综合久久 | 忘忧草秋观看未满十八 | 国产精品.XX视频.XXTV | 国产亚洲精品网站在线视频 | 色即是空 BT | 嗯啊快停下我是你老师啊H 嗯啊快拔出来我是你老师视频 | 四虎亚洲中文字幕永久在线 | 芭乐视频免费资源在线观看 | 日韩免费一级毛片 | 美女洗澡脱得一二干净 | 黑人巨摘花破女处 | 囯产精品久久久久免费蜜桃 |