From : https://blog.csdn.net/moonpure/article/details/52056153
從學(xué)習(xí).NET以來(lái)钠右,優(yōu)雅的編程風(fēng)格综芥,極度簡(jiǎn)單的可擴(kuò)展性,足夠強(qiáng)大開(kāi)發(fā)工具反砌,極小的學(xué)習(xí)曲線(xiàn)雾鬼,讓我對(duì)這個(gè)平臺(tái)產(chǎn)生了濃厚的興趣,在工作和學(xué)習(xí)中也積累了一些開(kāi)源的組件宴树,就目前想到的先整理于此策菜,如果再想到,就繼續(xù)補(bǔ)充這篇日志酒贬,日積月累又憨,就能形成一個(gè)自己的組件經(jīng)驗(yàn)庫(kù)。
Microsoft Velocity:微軟自家分布式緩存服務(wù)框架锭吨。
Memcahed:一套分布式的高速緩存系統(tǒng)蠢莺,目前被許多網(wǎng)站使用以提升網(wǎng)站的訪(fǎng)問(wèn)速度。
Redis:是一個(gè)高性能的KV數(shù)據(jù)庫(kù)零如。?它的出現(xiàn)很大程度補(bǔ)償了Memcached在某些方面的不足躏将。
EnyimMemcached:訪(fǎng)問(wèn)Memcached最優(yōu)秀的.NET客戶(hù)端,集成不錯(cuò)的分布式均衡算法考蕾。
OXITE:微軟ASP.NET MVC案例演示框架。
PetShop:微軟ASP.NET寵物商店肖卧。
Orchard:國(guó)外一個(gè)MVC開(kāi)源的博客系統(tǒng)。
SSCLI:微軟在NET Framework 2.0時(shí)代的開(kāi)源代碼塞帐。
DasBlog:國(guó)外一個(gè)基于ASP.NET的博客系統(tǒng)。
BlogEngine.NET:國(guó)外一款免費(fèi)開(kāi)源的博客系統(tǒng)壁榕。
Dotnetnuke.NET:一套非常優(yōu)秀的基于ASP.NET的開(kāi)源門(mén)戶(hù)網(wǎng)站程序赎瞎。
Discuz.NET:國(guó)內(nèi)開(kāi)源的論壇社區(qū)系統(tǒng)。
nopCommerce和Aspxcommerce:國(guó)外一套高質(zhì)量的開(kāi)源B2C網(wǎng)站系統(tǒng)。
JumboTCMS和DTCMS:國(guó)內(nèi)兩款開(kāi)源的網(wǎng)站管理系統(tǒng):
Log4Net.dll:輕量級(jí)的免費(fèi)開(kāi)源.NET日志記錄框架喳篇。
Enterprise Library Log Application Black:微軟企業(yè)庫(kù)日志記錄。
Elmah:實(shí)現(xiàn)最流行的ASP.NET應(yīng)用異常日志記錄框架麸澜。
NLog:是一個(gè)簡(jiǎn)單靈活的日志記錄類(lèi)庫(kù),性能比Log4Net高炊邦,使用和維護(hù)難度低。
關(guān)于NoSQL數(shù)據(jù)庫(kù):
Mongodb:分布式文件存儲(chǔ)數(shù)據(jù)庫(kù)熟史。
Membase:家族的一個(gè)新的重量級(jí)的成員馁害。
Quartz.NET:開(kāi)源的作業(yè)調(diào)度和自動(dòng)任務(wù)框架。
Topshelf:另一種創(chuàng)建Windows服務(wù)的開(kāi)源框架
Unity:微軟patterns&practicest團(tuán)隊(duì)開(kāi)發(fā)的IOC依賴(lài)注入框架蹂匹,支持AOP橫切關(guān)注點(diǎn)碘菜。
MEF(Managed Extensibility Framework):是一個(gè)用來(lái)擴(kuò)展.NET應(yīng)用程序的框架,可開(kāi)發(fā)插件系統(tǒng)限寞。
Spring.NET:依賴(lài)注入忍啸、面向方面編程(AOP)、數(shù)據(jù)訪(fǎng)問(wèn)抽象,履植、以及ASP.NET集成计雌。
Autofac:最流行的依賴(lài)注入和IOC框架,輕量且高性能静尼,對(duì)項(xiàng)目代碼幾乎無(wú)任何侵入性白粉。
PostSharp:實(shí)現(xiàn)靜態(tài)AOP橫切關(guān)注點(diǎn),使用簡(jiǎn)單鼠渺,功能強(qiáng)大鸭巴,對(duì)目標(biāo)攔截的方法無(wú)需任何改動(dòng)。
Ninject:基于.NET輕量級(jí)開(kāi)源的依賴(lài)注入IOC框架
EF(ADO.NET Entity Framework):微軟基于ADO.NET開(kāi)發(fā)的ORM框架拦盹。
Nhibernate:面向.NET環(huán)境的輕量級(jí)的ORM框架鹃祖。
SqlMapper.cs:用于小項(xiàng)目的通用的C#數(shù)據(jù)庫(kù)訪(fǎng)問(wèn)類(lèi)。
AutoMapper:流行的對(duì)象映射框架普舆,可減少大量硬編碼恬口,很小巧靈活,性能表現(xiàn)也可接受沼侣。
SubSonic:優(yōu)秀的開(kāi)源的ORM映射框架祖能,同時(shí)提供符合自身需要的代碼生成器。
FluentData:開(kāi)源的基于Fluent API的鏈?zhǔn)讲樵?xún)ORM輕量級(jí)框架蛾洛。
Dapper:輕量級(jí)高性能基于EMIT生成的ORM框架养铸。
EmitMapper:性能較高的ORM框架雁芙,運(yùn)行時(shí)通過(guò)EMIT動(dòng)態(tài)生成IL代碼,并非采用反射機(jī)制钞螟。
格式和數(shù)據(jù)類(lèi)型轉(zhuǎn)換
Newtonsoft.Json:目前.NET開(kāi)發(fā)中最流行的JSON序列化庫(kù)兔甘,為新版的WebApi庫(kù)提供基礎(chǔ)。
System.JSON.dll:微軟自己開(kāi)發(fā)的JSON序列化組件(需要單獨(dú)下載)
DataContractJsonSerializer 和 DataContractXmlSerializer:微軟在WCF中使用的序列化器鳞滨。
JavaScriptSerializer:微軟默認(rèn)針對(duì)WEB開(kāi)發(fā)者提供的JSON格式化器洞焙。
iTextSharp拯啦、PDFsharp 和 PDF.NET:通過(guò).NET處理和生成PDF文檔的組件。
SharpZipLib.dll:免費(fèi)開(kāi)源的ZIP和GZIP文件解壓縮組件仙蛉。
Math.NET:強(qiáng)大的數(shù)學(xué)運(yùn)算荠瘪、微積分哀墓、解方程和科學(xué)運(yùn)算篮绰。
DocX:不需要安裝word軟件吠各,通過(guò)C#操作word文件勉抓。
SharpSerializer:開(kāi)源XML和藕筋、二進(jìn)制隐圾、JSON、壓縮和優(yōu)化框架蜜笤。
Clay?dynamic:開(kāi)源的動(dòng)態(tài)語(yǔ)言dynamic框架讓您形如javascript的方式創(chuàng)建對(duì)象把兔。
ExposedObject:在類(lèi)的外部通過(guò)動(dòng)態(tài)語(yǔ)言dynamic的方式訪(fǎng)問(wèn)私有成員。
PrivateObject:微軟單元測(cè)試框架中便捷在外部調(diào)用類(lèi)內(nèi)部私有成員的一個(gè)類(lèi)。
MONO.NET:跨平臺(tái)的.NET運(yùn)行環(huán)境聘惦,讓.NET跨平臺(tái)運(yùn)行成為可能善绎。
DotGnu Portable.NET:類(lèi)似于MONO.NET的跨平臺(tái)運(yùn)行時(shí)禀酱。
Phalanger:將PHP編譯成.NET牧嫉,可實(shí)現(xiàn)PHP與.NET互操作酣藻。
VMDotNet:中國(guó)移動(dòng)飛信所使用過(guò)的.NET運(yùn)行時(shí)辽剧。
Unity3D:微軟大力支持的機(jī)遇C#和JavaScript的跨平臺(tái)游戲開(kāi)發(fā)框架。
Cassini偷崩、IIS Express和Cassinidev:開(kāi)源的ASP.NET執(zhí)行環(huán)境阐斜。
Katana:微軟基于OWIN規(guī)范實(shí)現(xiàn)的非IIS寄宿ASP.NET和MVC等智听。
IKVM.NET:基于.NET的JAVA虛擬機(jī)到推,讓JAVA運(yùn)行在.NET之上莉测。
Jumony Core:基于.NET開(kāi)發(fā)的HTML引擎唧喉。
Microsoft.mshtml.dll、Winista.HtmlParser.dll 和 HtmlAgilityPack.dll:解析處理HTML文檔的框架董朝。
JavaScript.NET和ClearScript(微軟出品):基于.NET開(kāi)發(fā)的JavaScript引擎子姜。
NCrawler:其HTML處理引擎htmlagilitypack的的開(kāi)源網(wǎng)絡(luò)爬蟲(chóng)軟件哥捕。
AntiXSS:微軟官方預(yù)防跨站XSS腳本入侵攻擊的開(kāi)源類(lèi)庫(kù)遥赚,它通過(guò)白名單機(jī)制進(jìn)行內(nèi)容編碼。
YUICompressor.NET讲坎、Microsoft Ajax Minifier 和 Google Closure Compiler:JavaScrip和CSS壓縮器衣赶。
NancyFx:是一個(gè)不錯(cuò)的輕量級(jí)開(kāi)源.NET WEB框架府瞄。如果想快速做個(gè)簡(jiǎn)單的WEB應(yīng)用遵馆。
AspNetPager:國(guó)內(nèi)知名的ASP.NET分頁(yè)控件丰榴,支持多種分頁(yè)方式。
NOPI.dll:導(dǎo)出Excel報(bào)表的插件(基于微軟OpenXml實(shí)現(xiàn))(nopi.css.dl通過(guò)css設(shè)置樣式)
Enterprise Library:微軟針對(duì)企業(yè)級(jí)應(yīng)用開(kāi)發(fā)的最佳實(shí)踐組件换况。
PowerCollections:國(guó)外一個(gè)牛人寫(xiě)的高級(jí)開(kāi)源集合戈二。
移動(dòng)互聯(lián)網(wǎng)和云計(jì)算
PushSharp:通過(guò).NET向各種移動(dòng)平臺(tái)推送消息觉吭。
mono for android:用.NET語(yǔ)言開(kāi)發(fā)安卓應(yīng)用:
MonoTouch:用.NET語(yǔ)言開(kāi)發(fā)IOS應(yīng)用仆邓。
PhoneGap和AppCan:跨平臺(tái)基于HTML5的移動(dòng)開(kāi)發(fā)平臺(tái)。
Cordova:PhoneGap貢獻(xiàn)給Apache后的開(kāi)源項(xiàng)目徙硅,是驅(qū)動(dòng)PhoneGap的核心引擎。
網(wǎng)絡(luò)通信和網(wǎng)絡(luò)協(xié)議
SuperSocket:基于.NET輕量級(jí)的可擴(kuò)展的Socket開(kāi)發(fā)框架峻汉。
SuperWebSocket:通過(guò).NET實(shí)現(xiàn)TML5 WebSocket框架。
XProxy:支持插件的基礎(chǔ)代理程序集业簿,內(nèi)置NAT梅尤、加解密、反向巷燥、直接和間接代理缰揪。
Paint.NET:基于.NET小巧靈活強(qiáng)大的圖形處理開(kāi)源項(xiàng)目钝腺。
Imagemagick.NET:用C#對(duì)開(kāi)源圖像處理組件Imagemagick的封裝赞厕。
Skimpt:基于.NET開(kāi)源的屏幕截圖軟件皿桑。
ImageGlue.NET:商業(yè)的圖像處理組件诲侮,支持的格式列了一大堆。
Sprite and Image Optimization Framework:微軟CSS精靈粉私,多圖合成一張大圖和CSS樣式诺核。
DevExpress:一個(gè)全球知名的桌面應(yīng)用程序UI控件庫(kù)。
Prism:微軟開(kāi)發(fā)的針對(duì)WPF和Silverlight的MVVM框架漓摩,通過(guò)功能模塊化的思想入客,來(lái)講復(fù)雜的業(yè)務(wù)功能和UI耦合性進(jìn)行分離桌硫。
WPFToolkit 和 Fluent Ribbon Control Suite:開(kāi)發(fā)類(lèi)似于Office風(fēng)格的Ribbon菜單铆隘。
Faker.Net:方便生成大批量測(cè)試數(shù)據(jù)的框架膀钠。
Nunit:一個(gè)輕量級(jí)的單元測(cè)試框架。
Moq:非常流行的Mock框架融击,支持LINQ尊浪,靈活且高性能封救。
xUnit:比NUnit更好的單元測(cè)試框架兴泥,升級(jí)改進(jìn)版的Nunit框架。
MiniProfiler和Glimpse:基于MVC的兩款性能事件監(jiān)控框架如绸。
KtmIntegration:一個(gè)支持NTFS文件系統(tǒng)的事務(wù)開(kāi)源類(lèi)旭贬。
NET Transactional File Manager:對(duì)文件系統(tǒng)操作(復(fù)制稀轨、移動(dòng)和刪除)加入事務(wù)支持。
Lucene.net:流行高性能的全文索引庫(kù)方妖,可用于為各類(lèi)信息提供強(qiáng)大的搜索功能罚攀。
Lucene.Net.Analysis.PanGu:支持Lucene.Net最新版的盤(pán)古中文分詞擴(kuò)展庫(kù)斋泄。
FluentValidation for .NET:基于LINQ表達(dá)式方法鏈Fluent接口驗(yàn)證組件炫掐。
Microsoft.Practices.EnterpriseLibrary.Validation.dll:微軟企業(yè)庫(kù)驗(yàn)證程序塊。
CuttingEdge.Conditions:基于Fluent接口方法練接口的契約編程組件。
DotNetOpenAuth:讓網(wǎng)站具備支持OpenID摔认、OAuth参袱、InfoCard等身份驗(yàn)證的能力抹蚀。
Visifire:一套效果非常好的WPF圖表控件环壤,支持3D繪制郑现、曲線(xiàn)荧降、折線(xiàn)朵诫、扇形、環(huán)形和梯形废累。
SparrowToolkit:一套WPF圖表控件集九默,支持繪制動(dòng)態(tài)曲線(xiàn),可繪制示波器殿遂、CPU使用率和波形墨礁。
DynamicDataDisplay:微軟開(kāi)源的WPF動(dòng)態(tài)曲線(xiàn)圖恩静,線(xiàn)圖驶乾、氣泡圖和熱力圖级乐。
可以擴(kuò)充消息隊(duì)列類(lèi)別风科,如:Kafka是一種分布式的贼穆,基于發(fā)布/訂閱的消息系統(tǒng)兰粉。主要設(shè)計(jì)目標(biāo)如下:
以時(shí)間復(fù)雜度為O(1)的方式提供消息持久化能力崖蜜,即使對(duì)TB級(jí)以上數(shù)據(jù)也能保證常數(shù)時(shí)間復(fù)雜度的訪(fǎng)問(wèn)性能豫领。
高吞吐率等恐。即使在非常廉價(jià)的商用機(jī)器上也能做到單機(jī)支持每秒100K條以上消息的傳輸囱稽。
支持Kafka Server間的消息分區(qū)战惊,及分布式消費(fèi)吞获,同時(shí)保證每個(gè)Partition內(nèi)的消息順序傳輸谚鄙。
同時(shí)支持離線(xiàn)數(shù)據(jù)處理和實(shí)時(shí)數(shù)據(jù)處理各拷。
Scale out:支持在線(xiàn)水平擴(kuò)展咧织。
RabbitMQ
RabbitMQ是使用Erlang編寫(xiě)的一個(gè)開(kāi)源的消息隊(duì)列省艳,本身支持很多的協(xié)議:AMQP约炎,XMPP, SMTP, STOMP八回,也正因如此,它非常重量級(jí)艰管,更適合于企業(yè)級(jí)的開(kāi)發(fā)途乃。同時(shí)實(shí)現(xiàn)了Broker構(gòu)架乖仇,這意味著消息在發(fā)送給客戶(hù)端時(shí)先在中心隊(duì)列排隊(duì)娘赴。對(duì)路由规哲,負(fù)載均衡或者數(shù)據(jù)持久化都有很好的支持关顷。
Redis
Redis是一個(gè)基于Key-Value對(duì)的NoSQL數(shù)據(jù)庫(kù),開(kāi)發(fā)維護(hù)很活躍。雖然它是一個(gè)Key-Value數(shù)據(jù)庫(kù)存儲(chǔ)系統(tǒng)宗雇,但它本身支持MQ功能舞虱,所以完全可以當(dāng)做一個(gè)輕量級(jí)的隊(duì)列服務(wù)來(lái)使用。對(duì)于RabbitMQ和Redis的入隊(duì)和出隊(duì)操作,各執(zhí)行100萬(wàn)次,每10萬(wàn)次記錄一次執(zhí)行時(shí)間。測(cè)試數(shù)據(jù)分為128Bytes邑闲、512Bytes褪子、1K和10K四個(gè)不同大小的數(shù)據(jù)胚股。實(shí)驗(yàn)表明:入隊(duì)時(shí),當(dāng)數(shù)據(jù)比較小時(shí)Redis的性能要高于RabbitMQ,而如果數(shù)據(jù)大小超過(guò)了10K活尊,Redis則慢的無(wú)法忍受绰疤;出隊(duì)時(shí)癣猾,無(wú)論數(shù)據(jù)大小像捶,Redis都表現(xiàn)出非常好的性能硼莽,而RabbitMQ的出隊(duì)性能則遠(yuǎn)低于Redis匆光。
ZeroMQ
ZeroMQ號(hào)稱(chēng)最快的消息隊(duì)列系統(tǒng),尤其針對(duì)大吞吐量的需求場(chǎng)景震桶。ZeroMQ能夠?qū)崿F(xiàn)RabbitMQ不擅長(zhǎng)的高級(jí)/復(fù)雜的隊(duì)列忙厌,但是開(kāi)發(fā)人員需要自己組合多種技術(shù)框架爹土,技術(shù)上的復(fù)雜度是對(duì)這MQ能夠應(yīng)用成功的挑戰(zhàn)琼娘。ZeroMQ具有一個(gè)獨(dú)特的非中間件的模式挪拟,你不需要安裝和運(yùn)行一個(gè)消息服務(wù)器或中間件惯雳,因?yàn)槟愕膽?yīng)用程序?qū)缪葸@個(gè)服務(wù)器角色。你只需要簡(jiǎn)單的引用ZeroMQ程序庫(kù),可以使用NuGet安裝订歪,然后你就可以愉快的在應(yīng)用程序之間發(fā)送消息了。但是ZeroMQ僅提供非持久性的隊(duì)列诈豌,也就是說(shuō)如果宕機(jī)油够,數(shù)據(jù)將會(huì)丟失焕窝。其中,Twitter的Storm 0.9.0以前的版本中默認(rèn)使用ZeroMQ作為數(shù)據(jù)流的傳輸(Storm從0.9版本開(kāi)始同時(shí)支持ZeroMQ和Netty作為傳輸模塊)起愈。
ActiveMQ
ActiveMQ是Apache下的一個(gè)子項(xiàng)目笛辟。 類(lèi)似于ZeroMQ管钳,它能夠以代理人和點(diǎn)對(duì)點(diǎn)的技術(shù)實(shí)現(xiàn)隊(duì)列醇滥。同時(shí)類(lèi)似于RabbitMQ不跟,它少量代碼就可以高效地實(shí)現(xiàn)高級(jí)應(yīng)用場(chǎng)景购城。
Kafka/Jafka
Kafka是Apache下的一個(gè)子項(xiàng)目漆诽,是一個(gè)高性能跨語(yǔ)言分布式發(fā)布/訂閱消息隊(duì)列系統(tǒng)箭昵,而Jafka是在Kafka之上孵化而來(lái)的泡一,即Kafka的一個(gè)升級(jí)版哨啃。具有以下特性:快速持久化珍特,可以在O(1)的系統(tǒng)開(kāi)銷(xiāo)下進(jìn)行消息持久化祝峻;高吞吐,在一臺(tái)普通的服務(wù)器上既可以達(dá)到10W/s的吞吐速率;完全的分布式系統(tǒng)莱找,Broker酬姆、Producer、Consumer都原生自動(dòng)支持分布式宋距,自動(dòng)實(shí)現(xiàn)負(fù)載均衡;支持Hadoop數(shù)據(jù)并行加載症脂,對(duì)于像Hadoop的一樣的日志數(shù)據(jù)和離線(xiàn)分析系統(tǒng)谚赎,但又要求實(shí)時(shí)處理的限制,這是一個(gè)可行的解決方案诱篷。Kafka通過(guò)Hadoop的并行加載機(jī)制統(tǒng)一了在線(xiàn)和離線(xiàn)的消息處理壶唤。Apache Kafka相對(duì)于ActiveMQ是一個(gè)非常輕量級(jí)的消息系統(tǒng),除了性能非常好之外棕所,還是一個(gè)工作良好的分布式系統(tǒng)闸盔。