.NET平台常用的框架整理

  • 时间:
  • 浏览:0

Kafka是Apache下的另另有有三个小子项目,是另另有有三个小高性能跨语言分布式发布/订阅消息队列系统,而Jafka是在Kafka之上孵化而来的,即Kafka的另另有有三个小升级版。具有以下价值形式:快速持久化,还需要在O(1)的系统开销下进行消息持久化;高吞吐,在一台普通的服务器上既还需要达到10W/s的吞吐波特率;全部的分布式系统,Broker、Producer、Consumer都原生自动支持分布式,自动实现负载均衡;支持Hadoop数据并行加载,对于像Hadoop的一样的日志数据和离线分析系统,但又要求实时处置的限制,这是另另有有三个小可行的处置方案。Kafka通过Hadoop的并行加载机制统一了在线和离线的消息处置。Apache Kafka相对于ActiveMQ是另另有有三个小非常轻量级的消息系统,除了性能非常好之外,还是另另有有三个小工作良好的分布式系统。

Katana:微软基于OWIN规范实现的非IIS寄宿ASP.NET和MVC等。

Clay dynamic:开源的动态语言dynamic框架让您形如JavaScript的妙招创建对象。

Sprite and Image Optimization Framework:微软CSS精灵,多图合成一张大图和CSS样式。

NOPI.dll:导出Excel报表的插件(基于微软OpenXml实现)(nopi.css.dl通过css设置样式)

ImageGlue.NET:商业的图像处置组件,支持的格式列了一大堆。

Imagemagick.NET:用C#对开源图像处置组件Imagemagick的封装。

分布式缓存框架:

OXITE:微软ASP.NET MVC案例演示框架。

AntiXSS:微软官方预防跨站XSS脚本入侵攻击的开源类库,它通过白名单机制进行内容编码。

Microsoft Velocity:微软自家分布式缓存服务框架。

FluentData:开源的基于Fluent API的链式查询ORM轻量级框架。

RabbitMQ

Unity3D:微软大力支持的机遇C#和JavaScript的跨平台游戏开发框架。

本文转自 bxst 51CTO博客,原文链接:http://blog.51cto.com/150013670/1944029

JavaScriptSerializer:微软默认针对WEB开发者提供的JSON格式化器。

Scale out:支持在线水平扩展。

Newtonsoft.Json:目前.NET开发中最流行的JSON序列化库,为新版的WebApi库提供基础。

Redis是另另有有三个小基于Key-Value对的NoSQL数据库,开发维护很活跃。着实它是另另有有三个小Key-Value数据库存储系统,但它并不是支持MQ功能,本来全部还需要当做另另有有三个小轻量级的队列服务来使用。对于RabbitMQ和Redis的入队和出队操作,各执行5000万次,每7万次记录一次执行时间。测试数据分为128Bytes、512Bytes、1K和10K三个小不同大小的数据。实验表明:入队时,当数据比较小时Redis的性能要高于RabbitMQ,而不可能 数据大小超过了10K,Redis则慢的无法忍受;出队时,无论数据大小,Redis都表现出非常好的性能,而RabbitMQ的出队性能则远低于Redis。

Microsoft.mshtml.dll、Winista.HtmlParser.dll 和 HtmlAgilityPack.dll:解析处置HTML文档的框架。

Dapper:轻量级高性能基于EMIT生成的ORM框架。

Membase:家族的另另有有三个小新的重量级的成员。

Visifire:一套效果非常好的WPF图表控件,支持3D绘制、曲线、折线、扇形、环形和梯形。

NET Transactional File Manager:对文件系统操作(克隆、移动和删除)加入事务支持。

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

WPFToolkit 和 Fluent Ribbon Control Suite:开发同类于Office风格的Ribbon菜单。

DevExpress:另另有有三个小全球知名的桌面程序UI控件库。

高吞吐率。即使在非常廉价的商用机器上要能做到单机支持每秒5000K条以上消息的传输。

RabbitMQ是使用Erlang编写的另另有有三个小开源的消息队列,并不是支持本来的协议:AMQP,XMPP, SMTP, STOMP,也正因如此,它非常重量级,更适合于企业级的开发。共同实现了Broker构架,这原因消息在发送给客户端时先在中心队列排队。对路由,负载均衡不可能 数据持久化都不 很好的支持。

Unity:微软patterns&practicest团队开发的IOC依赖注入框架,支持AOP横切关注点。

EF(ADO.NET Entity Framework):微软基于ADO.NET开发的ORM框架。

MiniProfiler和Glimpse:基于MVC的两款性能事件监控框架。

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

Redis

Moq:非常流行的Mock框架,支持LINQ,灵活且高性能。

spring.NET:依赖注入、面向方面编程(AOP)、数据访问抽象,、以及ASP.NET集成。

Discuz.NET:国内开源的论坛社区系统。

System.JSON.dll:微软有些人开发的JSON序列化组件(需要单独下载)

DotGnu Portable.NET:同类于MONO.NET的跨平台运行时。

SuperWebSocket:通过.NET实现TML5 WebSocket框架。

Paint.NET:基于.NET小巧灵活强大的图形处置开源项目。

EmitMapper:性能较高的ORM框架,运行时通过EMIT动态生成IL代码,暂且采用反射机制。

MONO.NET:跨平台的.NET运行环境,让.NET跨平台运行成为不可能 。

Log4Net.dll:轻量级的免费开源.NET日志记录框架。

CuttingEdge.Conditions:基于Fluent接口妙招练接口的契约编程组件。

Autofac:最流行的依赖注入和IOC框架,轻量且高性能,对项目代码几乎无任何侵入性。

XProxy:支持插件的基础代理程序集,内置NAT、加解密、反向、直接和间接代理。

Lucene.Net.Analysis.PanGu:支持Lucene.Net最新版的盘古中文分词扩展库。

BlogEngine.NET:国外一款免费开源的博客系统。

SuperSocket:基于.NET轻量级的可扩展的Socket开发框架。

ActiveMQ

IKVM.NET:基于.NET的Java虚拟机,让JAVA运行在.NET之上。

SparrowToolkit:一套WPF图表控件集,支持绘制动态曲线,可绘制示波器、CPU使用率和波形。

VMDotNet:中国移动飞信所使用过的.NET运行时。

还需要扩充消息队列类别,如:Kafka是并不是分布式的,基于发布/订阅的消息系统。主要设计目标如下:

Elmah:实现最流行的ASP.NET应用异常日志记录框架。

iTextSharp、PDFsharp 和 PDF.NET:通过.NET处置和阳成PDF文档的组件。

PushSharp:通过.NET向各种移动平台推送消息。

ExposedObject:在类的结构通过动态语言dynamic的妙招访问私有成员。

NancyFx:是另另有有三个小不错的轻量级开源.NET WEB框架。不可能 想快速做个简单的WEB应用。

SSCLI:微软在NET Framework 2.0时代的开源代码。

PowerCollections:国外另另有有三个小牛人写的高级开源集合。

AspNetPager:国内知名的ASP.NET分页控件,支持多种分页妙招。

NCrawler:其HTML处置引擎htmlagilitypack的的开源网络爬虫软件。

Faker.Net:方便生成大批量测试数据的框架。

FluentValidation for .NET:基于LINQ表达式妙招链Fluent接口验证组件。

xUnit:比NUnit更好的单元测试框架,升级改进版的Nunit框架。

Prism:微软开发的针对WPF和Silverlight的MVVM框架,通过功能模块化的思想,来讲繁复的业务功能和UI耦合性进行分离。

Nunit:另另有有三个小轻量级的单元测试框架。

Redis:是另另有有三个小高性能的KV数据库。 它的出現很大程度补偿了Memcached在有些方面的欠缺。

JavaScript.NET和ClearScript(微软出品):基于.NET开发的JavaScript引擎。

MEF(Managed Extensibility Framework):是另另有有三个小用来扩展.NET程序的框架,可开发插件系统。

Cassini、IIS Express和Cassinidev:开源的ASP.NET执行环境。

PrivateObject:微软单元测试框架中便捷在结构调用类结构私有成员的另另有有三个小类。

Memcahed:一套分布式的高速缓存系统,目前被有些网站使用以提升网站的访问波特率。

JumboTCMS和DTCMS:国内两款开源的网站管理系统:

共同支持离线数据处置和实时数据处置。

PostSharp:实现静态AOP横切关注点,使用简单,功能强大,对目标拦截的妙招我很多 任何改动。

DasBlog:国外另另有有三个小基于ASP.NET的博客系统。

SubSonic:优秀的开源的ORM映射框架,共同提供符合自身需要的代码生成器。

Dotnetnuke.NET:一套非常优秀的基于ASP.NET的开源门户网站程序。

mono for Android:用.NET语言开发安卓应用:

Lucene.net:流行高性能的全文索引库,可用于为各类信息提供强大的搜索功能。

SharpZipLib.dll:免费开源的ZIP和GZIP文件解压缩组件。

ZeroMQ

MongoDB:分布式文件存储数据库。

DocX:需要安装word软件,通过C#操作word文件。

Phalanger:将PHP编译成.NET,可实现PHP与.NET互操作。

DynamicDataDisplay:微软开源的WPF动态曲线图,线图、气泡图和热力图。

SharpSerializer:开源XML和、二进制、JSON、压缩和优化框架。

Cordova:PhoneGap贡献给Apache后的开源项目,是驱动PhoneGap的核心引擎。

以时间繁复度为O(1)的妙招提供消息持久化能力,即使对TB级以上数据要能保证常数时间繁复度的访问性能。

DotNetOpenAuth:让网站具备支持OpenID、OAuth、InfoCard等身份验证的能力。

nopCommerce和Aspxcommerce:国外一套高质量的开源B2C网站系统。

Enterprise Library Log Application Black:微软企业库日志记录。

PetShop:微软ASP.Net宠物商店。

KtmIntegration:另另有有三个小支持NTFS文件系统的事务开源类。

MonoTouch:用.NET语言开发iOS应用。

Math.NET:强大的数学运算、微积分、解方程和科学运算。

Microsoft.Practices.EnterpriseLibrary.Validation.dll:微软企业库验证程序块。

SqlMapper.cs:用于小项目的通用的C#数据库访问类。

NLog:是另另有有三个小简单灵活的日志记录类库,性能比Log4Net高,使用和维护难度低。

AutoMapper:流行的对象映射框架,可减少少量硬编码,很小巧灵活,性能表现也可接受。

Jumony Core:基于.NET开发的HTML引擎。

Ninject:基于.NET轻量级开源的依赖注入IOC框架

ZeroMQ号称最快的消息队列系统,尤其针对大吞吐量的需求场景。ZeroMQ要能实现RabbitMQ不擅长的高级/繁复的队列,以后开发人员需要有些人组合多种技术框架,技术上的繁复度是对这MQ要能应用成功的挑战。ZeroMQ具有另另有有三个小独特的非后边件的模式,你需要安装和运行另另有有三个小消息服务器或后边件,不可能 你的程序将扮演這個服务器角色。你只需要简单的引用ZeroMQ程序库,还需要使用NuGet安装,以后你就还需要愉快的在程序之间发送消息了。以后ZeroMQ仅提供非持久性的队列,也本来说不可能 宕机,数据不可能 丢失。其中,Twitter的Storm 0.9.0以后的版本中默认使用ZeroMQ作为数据流的传输(Storm从0.9版本刚开始了了共同支持ZeroMQ和Netty作为传输模块)。

Orchard:国外另另有有三个小MVC开源的博客系统。

支持Kafka Server间的消息分区,及分布式消费,共同保证每个Partition内的消息顺序传输。

Topshelf:另并不是创建Windows服务的开源框架

Nhibernate:面向.NET环境的轻量级的ORM框架。

Quartz.NET:开源的作业调度和自动任务框架。

PhoneGap和AppCan:跨平台基于HTML5的移动开发平台。

Enterprise Library:微软针对企业级应用开发的最佳实践组件。

ActiveMQ是Apache下的另另有有三个小子项目。 同类于ZeroMQ,它要能以代理人和点对点的技术实现队列。共同同类于RabbitMQ,它少量代码就还需要高效地实现高级应用场景。

Kafka/Jafka

Skimpt:基于.NET开源的屏幕截图软件。

EnyimMemcached:访问Memcached最优秀的.NET客户端,集成不错的分布式均衡算法。