基於.NET平台常用的架構整理的詳細介紹

來源:互聯網
上載者:User
自從學習.NET以來,優雅的編程風格,極度簡單的可擴充性,足夠強大開發工具,極小的學習曲線,讓我對這個平台產生了濃厚的興趣,在工作和學習中也積累了一些開源的組件,就目前想到的先整理於此,如果再想到,就繼續補充這篇日誌,日積月累,就能形成一個自己的組件經驗庫。

分布式緩衝架構:

Microsoft Velocity:微軟自家分布式快取服務架構。

Memcahed:一套分布式的快取系統,目前被許多網站使用以提升網站的訪問速度。

Redis:是一個高效能的KV資料庫。 它的出現很大程度補償了Memcached在某些方面的不足。

EnyimMemcached:訪問Memcached最優秀的.NET用戶端,整合不錯的分布式均衡演算法。

開源的.NET系統推薦:

OXITE:微軟ASP.NET MVC案例示範架構。

PetShop:微軟ASP.NET寵物商店。

Orchard:國外一個MVC開源的部落格系統。

SSCLI:微軟在NET Framework 2.0時代的開原始碼。

DasBlog:國外一個基於ASP.NET的部落格系統。

BlogEngine.NET:國外一款免費開源的部落格系統。

Dotnetnuke.NET:一套非常優秀的基於ASP.NET的開源門戶網站程式。

Discuz.NET:國內開源的論壇社區系統。

nopCommerce和Aspxcommerce:國外一套高品質的開源B2C網站系統。

JumboTCMS和DTCMS:國內兩款開源的網站管理系統:

日誌記錄異常處理:

Log4Net.dll:輕量級的免費開源.NET日誌紀錄架構。

Enterprise Library Log Application Black:微軟企業庫日誌記錄。

Elmah:實現最流行的ASP.NET應用異常日誌紀錄架構。

NLog:是一個簡單靈活的日誌記錄類庫,效能比Log4Net高,使用和維護難度低。

關於NoSQL資料庫:

Mongodb:分布式檔案儲存體資料庫。

Membase:家族的一個新的重量級的成員。

自動任務調度架構

Quartz.NET:開源的作業調度和自動任務架構。

Topshelf:另一種建立Windows服務的開源架構

依賴注入IOC容器架構:

Unity:微軟patterns&practicest團隊開發的IOC依賴注入架構,支援AOP橫切關注點。

MEF(Managed Extensibility Framework):是一個用來擴充.NET應用程式的架構,可開發外掛程式系統。

Spring.NET:依賴注入、面向方面編程(AOP)、資料訪問抽象,、以及ASP.NET整合。

Autofac:最流行的依賴注入和IOC架構,輕量且高效能,對項目代碼幾乎無任何侵入性。

PostSharp:實現靜態AOP橫切關注點,使用簡單,功能強大,對目標攔截的方法無需任何改動。

Ninject:基於.NET輕量級開源的依賴注入IOC架構

常用的幾個ORM架構:

EF(ADO.NET Entity Framework):微軟基於ADO.NET開發的ORM架構。

Nhibernate:面向.NET環境的輕量級的ORM架構。

SqlMapper.cs:用於小項目的通用的C#資料庫訪問類。

AutoMapper:流行的對象映射架構,可減少大量寫入程式碼,很小巧靈活,效能表現也可接受。

SubSonic:優秀的開源的ORM映射架構,同時提供符合自身需要的代碼產生器。

FluentData:開源的基於Fluent API的鏈式查詢ORM輕量級架構。

Dapper:輕量級高效能基於EMIT產生的ORM架構。

EmitMapper:效能較高的ORM架構,運行時通過EMIT動態產生IL代碼,並非採用反射機制。

格式和資料類型轉換

Newtonsoft.Json:目前.NET開發中最流行的JSON序列化庫,為新版的WebApi庫提供基礎。

System.JSON.dll:微軟自己開發的JSON序列化組件(需要單獨下載)

DataContractJsonSerializer 和 DataContractXmlSerializer:微軟在WCF中使用的序列化器。

JavaScriptSerializer:微軟預設針對WEB開發人員提供的JSON格式化器。

iTextSharp、PDFsharp 和 PDF.NET:通過.NET處理和產生PDF文檔的組件。

SharpZipLib.dll:免費開源的ZIP和GZIP檔案解壓縮組件。

Math.NET:強大的數學運算、微積分、解方程和科學運算。

DocX:不需要安裝word軟體,通過C#操作word檔案。

SharpSerializer:開源XML和、二進位、JSON、壓縮和最佳化架構。

反射和動態語言

Clay dynamic:開源的動態語言dynamic架構讓您形如javascript的方式建立對象。

ExposedObject:在類的外部通過動態語言dynamic的方式訪問私人成員。

PrivateObject:微軟單元測試架構中便捷在外部調用類內部私人成員的一個類。

跨平台和運行時解決方案

MONO.NET:跨平台的.NET運行環境,讓.NET跨平台運行成為可能。

DotGnu Portable.NET:類似於MONO.NET的跨平台運行時。

Phalanger:將PHP編譯成.NET,可實現PHP與.NET互操作。

VMDotNet:中國移動飛信所使用過的.NET運行時。

Unity3D:微軟大力支援的機遇C#和JavaScript的跨平台遊戲開發架構。

Cassini、IIS Express和Cassinidev:開源的ASP.NET執行環境。

Katana:微軟基於OWIN規範實現的非IIS寄宿ASP.NET和MVC等。

IKVM.NET:基於.NET的JAVA虛擬機器,讓JAVA運行在.NET之上。

WEB開發和設計

Jumony Core:基於.NET開發的HTML引擎。

Microsoft.mshtml.dll、Winista.HtmlParser.dll 和 HtmlAgilityPack.dll:解析處理HTML文檔的架構。

JavaScript.NET和ClearScript(微軟出品):基於.NET開發的JavaScript引擎。

NCrawler:其HTML處理引擎htmlagilitypack的的開源網路爬蟲軟體。

AntiXSS:微軟官方預防跨站XSS指令碼入侵攻擊的開源類庫,它通過白名單機制進行內容編碼。

YUICompressor.NET、Microsoft Ajax Minifier 和 Google Closure Compiler:JavaScrip和CSS壓縮器。

NancyFx:是一個不錯的輕量級開源.NET WEB架構。如果想快速做個簡單的WEB應用。

AspNetPager:國內知名的ASP.NET分頁控制項,支援多種分頁方式。

NOPI.dll:匯出Excel報表的外掛程式(基於微軟OpenXml實現)(nopi.css.dl通過css設定樣式)

Enterprise Library:微軟針對企業級應用開發的最佳實務組件。

PowerCollections:國外一個牛人寫的進階開源集合。

移動互連網和雲端運算

PushSharp:通過.NET向各種移動平台推送訊息。

mono for android:用.NET語言開發安卓應用:

MonoTouch:用.NET語言開發IOS應用。

PhoneGap和AppCan:跨平台基於HTML5的移動開發平台。

Cordova:PhoneGap貢獻給Apache後的開源項目,是驅動PhoneGap的核心引擎。

網路通訊和網路通訊協定

SuperSocket:基於.NET輕量級的可擴充的Socket開發架構。

SuperWebSocket:通過.NET實現TML5 WebSocket架構。

XProxy:支援外掛程式的基礎代理程式組件,內建NAT、加解密、反向、直接和間接代理。

圖形和影像處理架構

Paint.NET:基於.NET小巧靈活強大的圖形處理開源項目。

Imagemagick.NET:用C#對開源影像處理組件Imagemagick的封裝。

Skimpt:基於.NET開源的螢幕軟體。

ImageGlue.NET:商業的影像處理組件,支援的格式列了一大堆。

Sprite and Image Optimization Framework:微軟CSS精靈,多圖合成一張大圖和CSS樣式。

傳統型應用程式架構

DevExpress:一個全球知名的傳統型應用程式UI控制項陳列庫。

Prism:微軟開發的針對WPF和Silverlight的MVVM架構,通過功能模組化的思想,來講複雜的業務功能和UI耦合性進行分離。

WPFToolkit 和 Fluent Ribbon Control Suite:開發類似於Office風格的Ribbon菜單。

測試和效能評估方面

Faker.Net:方便產生大批量測試資料的架構。

Nunit:一個輕量級的單元測試架構。

Moq:非常流行的Mock架構,支援LINQ,靈活且高效能。

xUnit:比NUnit更好的單元測試架構,升級改進版的Nunit架構。

MiniProfiler和Glimpse:基於MVC的兩款效能事件監控架構。

事務和分散式交易支援

KtmIntegration:一個支援NTFS檔案系統的事務開源類。

NET Transactional File Manager:對檔案系統操作(複製、移動和刪除)加入事務支援。

分詞、全文檢索索引和搜尋引擎

Lucene.net:流行高效能的全文索引庫,可用於為各類資訊提供強大的搜尋功能。

Lucene.Net.Analysis.PanGu:支援Lucene.Net最新版的Apsara Distributed File System中文分詞擴充庫。

資料驗證組件整理

FluentValidation for .NET:基於LINQ運算式方法鏈Fluent介面驗證組件。

Microsoft.Practices.EnterpriseLibrary.Validation.dll:微軟企業庫驗證程式塊。

CuttingEdge.Conditions:基於Fluent介面方法練介面的契約編程組件。

DotNetOpenAuth:讓網站具備支援OpenID、OAuth、InfoCard等身分識別驗證的能力。

開源圖表統計控制項:

Visifire:一套效果非常好的WPF圖表控制項,支援3D繪製、曲線、折線、扇形、環形和梯形。

SparrowToolkit:一套WPF圖表控制項集,支援繪製動態曲線,可繪製示波器、CPU使用率和波形。

DynamicDataDisplay:微軟開源的WPF動態曲線圖,線圖、泡泡圖和熱力圖。

可以擴充訊息佇列類別,如:Kafka是一種分布式的,基於發布/訂閱的訊息系統。主要設計目標如下:

以時間複雜度為O(1)的方式提供訊息持久化能力,即使對TB級以上資料也能保證常數時間複雜度的訪問效能。

高吞吐率。即使在非常廉價的商用機器上也能做到單機支援每秒100K條以上訊息的傳輸。

支援Kafka Server間的訊息分區,及分布式消費,同時保證每個Partition內的訊息順序傳輸。

同時支援離線資料處理和即時資料處理。

Scale out:支援線上水平擴充。

RabbitMQ

RabbitMQ是使用Erlang編寫的一個開源的訊息佇列,本身支援很多的協議:AMQP,XMPP, SMTP, STOMP,也正因如此,它非常重量級,更適合於企業級的開發。同時實現了Broker構架,這意味著訊息在發送給用戶端時先在中心隊列排隊。對路由,負載平衡或者資料持久化都有很好的支援。

Redis

Redis是一個基於Key-Value對的NoSQL資料庫,開發維護很活躍。雖然它是一個Key-Value資料庫儲存系統,但它本身支援MQ功能,所以完全可以當做一個輕量級的佇列服務來使用。對於RabbitMQ和Redis的入隊和出隊操作,各執行100萬次,每10萬次記錄一次執行時間。測試資料分為128Bytes、512Bytes、1K和10K四個不同大小的資料。實驗表明:入隊時,當資料比較小時Redis的效能要高於RabbitMQ,而如果資料大小超過了10K,Redis則慢的無法忍受;出隊時,無論資料大小,Redis都表現出非常好的效能,而RabbitMQ的出隊效能則遠低於Redis。

ZeroMQ

ZeroMQ號稱最快的訊息佇列系統,尤其針對大輸送量的需求情境。ZeroMQ能夠實現RabbitMQ不擅長的進階/複雜的隊列,但是開發人員需要自己組合多種技術架構,技術上的複雜度是對這MQ能夠應用成功的挑戰。ZeroMQ具有一個獨特的非中介軟體的模式,你不需要安裝和運行一個Message Service器或中介軟體,因為你的應用程式將扮演這個伺服器角色。你只需要簡單的引用ZeroMQ程式庫,可以使用NuGet安裝,然後你就可以愉快的在應用程式之間發送訊息了。但是ZeroMQ僅提供非持久性的隊列,也就是說如果宕機,資料將會丟失。其中,Twitter的Storm 0.9.0以前的版本中預設使用ZeroMQ作為資料流的傳輸(Storm從0.9版本開始同時支援ZeroMQ和Netty作為傳輸模組)。

ActiveMQ

ActiveMQ是Apache下的一個子項目。 類似於ZeroMQ,它能夠以代理人和點對點的技術實現隊列。同時類似於RabbitMQ,它少量代碼就可以高效地實現進階應用程式情境。

Kafka/Jafka

Kafka是Apache下的一個子項目,是一個高效能跨語言分布式發布/訂閱訊息佇列系統,而Jafka是在Kafka之上孵化而來的,即Kafka的一個升級版。具有以下特性:快速持久化,可以在O(1)的系統開銷下進行訊息持久化;高吞吐,在一台普通的伺服器上既可以達到10W/s的吞吐速率;完全的分布式系統,Broker、Producer、Consumer都原生自動支援分布式,自動實現負載平衡;支援Hadoop資料並行載入,對於像Hadoop的一樣的日誌資料和離線分析系統,但又要求即時處理的限制,這是一個可行的解決方案。Kafka通過Hadoop的並行載入機制統一了線上和離線的訊息處理。Apache Kafka相對於ActiveMQ是一個非常輕量級的訊息系統,除了效能非常好之外,還是一個工作良好的分布式系統。

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.