天天看點

.NET平台常用的架構整理

.NET平台常用的架構整理

分布式緩存架構

Microsoft Velocity:微軟自家分布式緩存服務架構。

Memcahed:一套分布式的高速緩存系統,目前被許多網站使用以提升網站的通路速度。

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

EnyimMemcached:通路Memcached最優秀的.NET用戶端,內建不錯的分布式均衡算法。

CacheManager  用于緩存的管理,支援Redis.Memcached,couchbase等 https://github.com/MichaCo/CacheManager

Redis和資料連接配接驅動架構

ServiceStack.Redis:https://github.com/ctstone/csredis

StackExchange.Redis:https://stackexchange.github.io/StackExchange.Redis/ReleaseNotes

csredis:https://github.com/ctstone/csredis

MySQL Connector:完全托管的 MySQL ADO.NET 資料庫提供程式、連接配接器

開源的.NET系統推薦

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

PetShop:微軟ASP.Net寵物商店。分層思想的代表。

eShopOnContainers:微服務架構和Docker容器的一個簡單的.Net Core的應用。微服務思想代表。

ABP(aspnetboilerplate),提供一系列工具用于web應用建立,支援 ASP.NET Core, ASP.NET MVC & Web API,也提供了web應用的模闆。領域驅動思想代表。  https://github.com/aspnetboilerplate/aspnetboilerplate(.net core 版本,tag分支有支援.net版本的)。

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

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

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

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

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

Discuz.NET:國内開源的論壇社群系統。

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

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

nopCommerce 開源電商網站,開發環境asp.net mvc(支援.net core),使用技術(autofac,ef,頁面插件等) https://github.com/nopSolutions/nopCommerce

LightGBM  用于機器學習 https://github.com/Microsoft/LightGBM

IdentityServer,使用者授權網站(支援openid和OAuth 2.0),可用于單點登入和第三方授權等

         https://github.com/IdentityServer/IdentityServer3(.net版本)

         https://github.com/IdentityServer/IdentityServer4(.net core版本)

日志記錄異常處理

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

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

Elmah:實作最流行的ASP.NET應用異常日志記錄架構。

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

關于NoSQL資料庫

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

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

自動任務排程架構

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

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

Hangfire  任務排程開發利器 https://github.com/HangfireIO/Hangfire

依賴注入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代碼,并非采用反射機制。

辦公系列架構(文檔操作)

NPIO:該項目是 .NET 版本的 POI 項目,原始的 Java 版本位于http://poi.apache.org/ 。

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

Open XML SDK:Open XML SDK 是一個開源庫,用于處理 Open XML 文檔。

ITextSharp:iText 是一個PDF庫,用于建立、修改、檢查和維護 (PDF)格式的文檔。

格式和資料類型轉換

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檔案解壓縮元件。

SharpSerializer:開源XML和、二進制、JSON、壓縮和優化架構。

人工智能與數學架構

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

Accord.NET:機器學習架構,包含了音頻和圖像處理的庫(計算機視覺、計算機聽覺、信号處理和統計)

文法解析和模闆引擎Template Engine

RazorEngine:基于微軟 Razor 解析器引擎的開源模闆引擎。官網。

Nustache:無邏輯模闆的開源庫。官網。

DotLiquid:Ruby Liquid 模闆語言的 C# 移植版本。

MarkdownSharp:C# 實作的開源 Markdown 處理器,在 Stack Overflow 中使用。

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

ExCSS:C# 的 CSS3 解析器開發庫。

HtmlAgilityPack:一個靈活的 HTML 解析器,可以對 DOM 進行讀寫,支援 XPATH 和 XSLT。

反射和動态語言

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文檔的架構。

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:國外一個牛人寫的進階開源集合。

包管理

NuGet:.NET 包管理器。官網

MyGet:為 NuGet、NPM、Bower 和 VSIX 提供程式包倉庫宿主,同樣提供 CI 服務。

Paket:.NET 的一個包依賴管理器,支援 NuGet 包和 GitHub 倉庫。

移動網際網路和雲計算

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、加解密、反向、直接和間接代理。

websocket-sharp:websocket-sharp是一個C#實作websocket協定用戶端和服務端,websocket-sharp支援RFC 6455;WebSocket用戶端和伺服器;消息壓縮擴充;安全連接配接;HTTP身份驗證;查詢字元串,起始标題和Cookie;通過HTTP代理伺服器連接配接;.NET Framework 3.5或更高版本(包括相容環境,如Mono)。

網絡通訊架構

SignalR:ASP.NET 庫,開發者可以通過它在 web 應用程式中非常簡單地實作實時功能。

Helios:一套高性能的Socket通信中間件。

圖形和圖像處理架構

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

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

Skimpt:基于.NET開源的螢幕截圖軟體。

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

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

NGraphics:NGraphics 是一個 .NET 跨平台矢量圖形渲染。

DynamicImage:高性能開源圖檔處理庫,用于 ASP.NET。

桌面應用程式架構

DevExpress:一個全球知名的桌面應用程式UI控件庫。

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

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

Netron Diagramming Library:開源圖形繪制元件 

                                                     http://www.csharpopensource.com/netrondiagramminglibrary/

                                                     https://sourceforge.net/projects/netron-reloaded/

測試和性能評估方面

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最新版的盤古中文分詞擴充庫。

ElasticSearch:http://nest.azurewebsites.net/

資料驗證元件整理

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動态曲線圖,線圖、氣泡圖和熱力圖。

安全性架構

OAuth:超輕量級 OAuth 1.0a 簽名生成庫,C# 編寫

ASP.NET Identity:用于 ASP.NET 應用程式的新身份系統。

IdentityServer:可擴充的 OAuth2 和 OpenID 連接配接提供程式架構

HashLib:HashLib 包含了幾乎所有你見過的雜湊演算法,它幾乎支援所有東西并且非常容易使用

編譯器和IDE架構

ILSpy:ILSpy 是一個開源的 .NET 程式集檢視器和反編譯器

Visual Studio Code:非常棒的編輯器,來自微軟,基于 GitHub Atom

MSBuild也是一個MIT License的開源軟體,可以在Github上看到它的 倉庫。

Visual Studio 插件

Resharper:Visual Studio 開發人員生産力工具

打包釋出和自動建構持續內建和更新架構

Wix Toolset:強大的工具集,用于建立你自己的 Windows 安裝程式

Squirrel:Squirrel 即是一套工具也是一個類庫,可以無安全管理 Windows 桌面程式的安裝和更新

MSBuild:微軟建構引擎(MSBuild)是 .NET 和 Visual Studio 的建構平台

Psake:基于 .NET 的自動化建構工具,使用 PowerShell 編寫

中間件與消息隊列

RabbitMQ

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

MassTransit  可用于建立基于消息的服務和應用,依賴于RabbitMQ  https://github.com/MassTransit/MassTransit

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具有一個獨特的非中間件的模式,你不需要安裝和運作一個消息伺服器或中間件,因為你的應用程式将扮演這個伺服器角色。你隻需要簡單的引用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是一個非常輕量級的消息系統,除了性能非常好之外,還是一個工作良好的分布式系統。

成在管理,敗在經驗;嬴在選擇,輸在不學!  貴在堅持!

歡迎關注作者頭條号 張傳甯IT講堂,擷取更多IT文章、視訊等優質内容。

.NET平台常用的架構整理

個人作品

1、BIMFace.Community.SDK.NET

     開源位址:https://gitee.com/NAlps/BIMFace.SDK

     系列部落格:https://www.cnblogs.com/SavionZhang/p/11424431.html

     系列視訊:https://www.cnblogs.com/SavionZhang/p/14258393.html

2、ZCN.NET.Common

     開源位址:https://gitee.com/NAlps/zcn.net.common

.NET平台常用的架構整理

技術棧

 1、Visual Studio、.C#/.NET、.NET Core、MVC、Web API、RESTful API、gRPC、SignalR、Python

 2、jQuery、Vue.js、Bootstrap

 3、資料庫:SQLServer、MySQL、PostgreSQL、Oracle、SQLite、Redis、MongoDB、ElasticSearch、TiDB、達夢DM、人大金倉、 神通、南大通用 GBase、華為 GaussDB 、騰訊 TDSQL 、阿裡 PolarDB、螞蟻金服 OceanBase、東軟 OpenBASE、浪潮雲溪資料庫 ZNBase

 4、ORM:Dapper、Entity Framework、FreeSql、SqlSugar、分庫分表、讀寫分離

 5、架構:領域驅動設計 DDD、ABP

 6、環境:跨平台、Windows、Linux(CentOS、麒麟、統信UOS、深度Linux)、maxOS、IIS、Nginx、Apach

 7、移動App:Android、IOS、HarmonyOS、微信、小程式、快應用、Xamarin、uni-app、MUI、Flutter、Framework7、Cordova、Ionic、React Native、Taro、NutUI、Smobiler

 雲原生、微服務、Docker、CI/CD、DevOps、K8S;

 Dapr、RabbitMQ、Kafka、分布式、大資料、高并發、負載均衡、中間件、RPC、ELK;

 .NET + Docker + jenkins + Github + Harbor + K8S;

出處:www.cnblogs.com/SavionZhang

作者:張傳甯   微軟MCP、系統架構設計師、系統內建項目管理工程師、科技部創新工程師。

          專注于微軟.NET技術(.NET Core、Web、MVC、WinForm、WPF)、通用權限管理系統、工作流引擎、自動化項目(代碼)生成器、SOA 、DDD、 雲原生(Docker、微服務、DevOps、CI/CD);PDF、CAD、BIM 審圖等研究與應用。

          多次參與電子政務、圖書教育、生産制造等企業級大型項目研發與管理工作。

          熟悉中小企業軟體開發過程:需求分析、架構設計、編碼測試、實施部署、項目管理。通過技術與管理幫助中小企業快速化實作網際網路技術全流程解決方案。

本文版權歸作者和部落格園共有,歡迎轉載,但未經作者同意必須保留此段聲明,且在文章頁面明顯位置給出原文連接配接,否則保留追究法律責任的權利。

如有問題,可以通過郵件[email protected]聯系。共同交流、互相學習。

如果您覺得文章對您有幫助,請點選文章右下角【推薦】。您的鼓勵是作者持續創作的最大動力!