成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

Apworks框架各種倉儲實現的性能基準測試

開發 后端
周末抽空簡單地對Apworks框架所支持的三種倉儲實現:Entity Framework、NHibernate以及MongoDB進行了性能基準測試,并對其結果進行對比。從對比的結果來看,MongoDB倉儲的性能要遠勝于其它兩者?;鶞蕼y試采用的是我在兩年前開發的一個基于Visual Studio Unit Test Framework的基準測試程序(名為:Visual Benchmark),該程序可以設定基準測試引擎,并對測試結果進行圖形化呈現。在本文末尾會簡要地對此軟件進行介紹,有興趣的朋友不妨了解一下。

單體測試的設計

由于Visual Benchmark是基于Visual Studio Unit Test Framework的單體測試用例的,因此,我們只需要在Visual Studio中開發有待測試的單體測試程序即可。在開發單體測試程序之前,首先讓我們了解一下Visual Benchmark所支持的“迭代基準測試”模式。所謂“迭代基準測試”,意思就是Visual Benchmark會循環地調用單體測試方法并在每次調用結束時,統計當前“代”中所消耗的CPU周期或者時間;當Visual Benchmark完成整個測試之后,會將各代的統計結果組織并顯示出來。在這個過程中,單體測試方法可以通過Visual Benchmark所提供的基準測試參數來獲得當前所處的“代”數(也就是循環因子的值),然后就可以基于這個“代”數對測試數據進行模擬,以反映出隨著測試數據的增長,單體測試方法的執行效率。

舉例來說,在測試三種不同的倉儲對于聚合的保存執行效率時,我首先在Visual Studio中新建了一個Unit Test類,并在類中定義了兩個成員變量:

  1. [TestClass] 
  2. public class InsertAggregateRootsTest 
  3.     private int thisIteration; 
  4.     private IEnumerable<SalesOrder> mockSalesOrders; 
  5.     // 其它部分暫時省略 

第一個成員變量thisIteration用來保存從Visual Benchmark傳入的“代”數;而第二個成員變量mockSalesOrders則是保存了一組即將通過倉儲插入的聚合模擬數據。

接下來,我在這個測試類中加入了Test Initialize的方法,以便在每次測試方法被調用前,執行一些數據初始化的操作。在這個方法中,會對以上兩個成員變量初始化,同時清空后臺數據庫,為執行測試做準備。

  1. [TestInitialize()] 
  2. public void MyTestInitialize() 
  3.     thisIteration = (int)BenchmarkRuntimeArgs.Instance.ThisIteration; 
  4.     mockSalesOrders = Helper.MockSalesOrders(thisIteration); 
  5.     Helper.ClearSQLServerTables(); 
  6.     Helper.ClearMongoDB(); 

在上面的方法中,首先使用BenchmarkRuntimeArgs.Instance.ThisIteration對thisIteration進行初始化,以便獲得當前測試的“代”。BenchmarkRuntimeArgs是一個跨應用程序域的單件(Singleton),在每次執行Benchmark之前都會被初始化。然后根據獲得的“代”數,創建聚合模擬數據。此處mockSalesOrders中所包含的數據量會隨著“代”數的增長而增加,以反映隨著數據量的增長,被測函數的性能趨勢。最后,使用Helper類清空后臺數據庫。

由于倉儲的實現是基于不同的應用框架,因此,在所有測試啟動前,需要對這些框架進行初始化。有寫過單體測試的朋友都知道,這部分邏輯應該寫在Class Initialize的方法中:

  1. [ClassInitialize()] 
  2. public static void MyClassInitialize(TestContext testContext) 
  3.     Database.SetInitializer<EntityFrameworkDbContext>(new 
  4.         DropCreateDatabaseIfModelChanges<EntityFrameworkDbContext>()); 
  5.     MongoDBRepositoryContext.RegisterConventions(); 
  6.     if (!BsonClassMap.IsClassMapRegistered(typeof(SalesLine))) 
  7.     { 
  8.         BsonClassMap.RegisterClassMap<SalesLine>(p => 
  9.         { 
  10.             p.AutoMap(); 
  11.             p.UnmapProperty<SalesOrder>(q => q.SalesOrder); 
  12.         }); 
  13.     } 

在這里并沒有使用代碼的方式對NHibernate框架進行初始化,因為NHibernate的初始化過程是由Apworks中的NHibernateApplicationConfiguration類型完成的,這個類型依賴應用程序的app/web.config文件。所以我們需要在單體測試項目中添加app.config以及相關的配置節點。篇幅原因,這里就不貼app.config的代碼了,文章末尾我會給出源代碼。Visual Benchmark支持在“客戶應用程序域”(Client AppDomain)中裝載app/web.config文件。

現在,可以開始寫測試方法了,以下是基于三種不同倉儲實現的測試方法。從各方法中我們可以看到,除了所創建的IRepositoryContext、IRepository的具體實現不同之外,其它的操作邏輯完全相同:即通過倉儲對聚合進行保存:

  1. [TestMethod] 
  2. public void EntityFramework() 
  3.     using (IRepositoryContext context = new EntityFrameworkRepositoryContext(new EntityFrameworkDbContext())) 
  4.     { 
  5.         IRepository<SalesOrder> salesOrderRepository = new EntityFrameworkRepository<SalesOrder>(context); 
  6.         foreach (var salesOrder in mockSalesOrders) 
  7.             salesOrderRepository.Add(salesOrder); 
  8.         context.Commit(); 
  9.     } 
  10.   
  11. [TestMethod] 
  12. public void NHibernate() 
  13.     using (IRepositoryContext context = new NHibernateContext(new NHibernateApplicationConfiguration())) 
  14.     { 
  15.         IRepository<SalesOrder> salesOrderRepository = new NHibernateRepository<SalesOrder>(context); 
  16.         foreach (var salesOrder in mockSalesOrders) 
  17.             salesOrderRepository.Add(salesOrder); 
  18.         context.Commit(); 
  19.     } 
  20.   
  21. [TestMethod] 
  22. public void MongoDB() 
  23.     using (IRepositoryContext context = new MongoDBRepositoryContext(new MongoDBRepositoryContextSettings())) 
  24.     { 
  25.         IRepository<SalesOrder> salesOrderRepository = new MongoDBRepository<SalesOrder>(context); 
  26.         foreach (var salesOrder in mockSalesOrders) 
  27.             salesOrderRepository.Add(salesOrder); 
  28.         context.Commit(); 
  29.     } 

執行測試

首先,我們在Visual Studio中測試這三個方法,以確保每個方法都能夠正確完成。在啟動測試之前,先回到上面的MyTestInitialize方法,將thisIteration設置為一個固定的整數值,比如20,以便測試能夠正常啟動。在完成三個方法的測試之后,我們可以通過Test Results窗口看到測試結果。

image

打開Visual Benchmark,新建一個Session,在“打開”對話框中,選擇已經編譯好的DLL文件,此時Visual Benchmark會將其中包含的所有的測試類和測試方法加載到左邊的樹形結構中。在樹形結構中,選中需要測試的方法,然后單擊“開始”按鈕,Visual Benchmark便會針對所選的測試方法進行基準測試。最后,會根據不同的測試引擎的設計,將結果顯示出來。

image

測試結果

Visual Benchmark能夠根據設置,采用一些減噪手段以盡量保證測試結果的真實性。通過所測結果不難看出,在我所測試的三個場景中,基于MongoDB實現的倉儲,性能要優于其它兩者。而NHibernate倉儲又要好于Entity Framework倉儲。

測試環境

以下是執行測試的環境配置:

CPU:Intel Core i5-540M Cores: 2 Logical: 4

Chipset:Intel QM57 (IbexPeak-M DO)

Memory:Hynix 666.7MHz (PC3-10600) 2048MB x1, Kingston 666.7MHz (PC3-10600) 4096MB x1. Totally 6144MB

OS:Microsoft Windows 7 Enterprise (x64) Build 7601

場景一:聚合保存

Insert

注:上圖中X軸表示的是“代”數,亦即模擬的聚合數量;Y軸表示執行時間(毫秒數)。下同。

場景二:聚合查詢

Retrieve

注:在此場景中,EntityFramework支線所表示的是使用Eager Loading將SalesOrder及其下所有Sales Lines實體讀出所開銷的時間;而EntityFramework_NoEagerLoad支線所表示的是僅讀出SalesOrder(不包括其下所有Sales Lines)所開銷的時間。

場景三:查詢所有并刪除

FindAndDelete

關于Visual Benchmark

Visual Benchmark是我在2010年開發的一款基于Visual Studio單體測試框架的性能基準測試程序,從整體上看,Visual Benchmark具有如下架構設計:

image

首先,Visual Benchmark和被測試的程序集都是基于Microsoft .NET Framework的,在Visual Benchmark中,基準測試的執行是以Session為單位的。Engine Management System為Visual Benchmark提供了安全的、可擴展的基準測試引擎管理系統,因此,通過這套管理系統,用戶可以選用各種不同的引擎進行測試,開發人員也可以根據自己的實際需求對引擎進行二次開發與定制,并應用到Visual Benchmark系統中。

其次,當Session被打開時,它會通過Remote Proxy將被測試的程序集裝載到客戶應用程序域(Client AppDomain)中。這樣做的理由是:1、能夠在完成測試后,以AppDomain.Unload的方式卸載被測試程序集;2、能夠在裝載程序集時,同時將app/web.config和resource都裝載到Client AppDomain中,以此模擬真實的執行環境。

功能技術特點

Visual Benchmark具有如下功能技術特點:

可定制的基準測量標尺:開發人員可以自己開發基準測試的測量標尺。目前僅支持兩種:StopwatchTickRuler和StopwatchMillisecondsRuler。上文的測試采用的是StopwatchMillisecondsRuler

可定制的測試引擎:開發人員可以根據需求定制開發測試引擎。框架提供了完整的引擎定制功能,這包括:引擎的元數據(例如名稱、作者、描述等)、版本、配置界面、結果顯示界面以及HTML文檔。目前支持Iterated Throughput、Simple、Simple Iteration以及Throughput四種引擎。上文的測試采用了Simple Iteration引擎

減噪選項:使用減噪選項以獲得更真實的測試數據。Visual Benchmark提供兩個減噪選項:在每次執行測試之前強制垃圾回收、丟棄第一次的測試結果。測試引擎也會根據情況提供獲取平均執行時間的選項

在客戶應用程序域(Client AppDomain)中執行基準測試:能夠對單體測試環境進行模擬,被測方法能夠正常地訪問配置文件和資源文件

跨AppDomain的單件(Singleton)實現:能夠方便地在單體測試方法中讀取Visual Benchmark的相關參數信息

多線程執行:用戶可以隨時停止Benchmark的執行

界面截圖

基于兩種不同引擎的執行結果顯示

image

測試引擎的配置界面與文檔界面

image

Session信息與客戶應用程序域(Client AppDomain)信息

image

總結

本文對Apworks框架中所支持的三種倉儲實現進行了性能上的基準測試,并得出了測試結果。在最開始的時候,我是打算結合Visual Studio的測試框架來完成這些工作的,但后來發現Visual Studio的測試框架所提供的功能并不能達到我的需求,之前也采用了Visual Studio的Load Test來做壓力測試,但是效果并不算太理想。在下才疏學淺,并沒有弄通Visual Studio提供的強大測試功能,所以也只能借用我之前寫的Visual Benchmark程序了。如果有讀者朋友知道如何在Visual Studio中完成類似的測試工作,還煩請告知在下,我會虛心向您學習。

下一步,我將對Apworks框架的線程安全性做一些評估,等到有了滿意的結果,我也會將相關經驗分享出來。

原文鏈接:http://www.cnblogs.com/daxnet/archive/2012/07/31/2616197.html

【編輯推薦】

 

責任編輯:彭凡 來源: 博客園
相關推薦

2016-09-23 16:36:25

LinuxPCPhoronix

2023-07-31 09:13:13

ValidatorGolang

2021-07-17 15:25:05

PHP 8.1基準測試開發

2024-03-06 18:09:06

Linux性能工具

2009-10-10 11:11:40

服務器測試

2025-01-06 06:10:00

開源.NEThttps://mp

2021-07-08 14:59:05

JMHMongodb數據

2022-03-29 11:48:40

Go泛型測試

2013-05-07 09:47:30

測試MySQLMySQL測試

2023-08-30 13:22:00

測試框架工具

2019-06-19 10:00:45

vue.jsimbajavascript

2023-12-21 14:02:35

機器學習深度學習

2011-07-19 09:35:46

.Net

2012-12-18 13:32:45

IBMdW

2015-06-17 13:58:22

Java序列化庫

2015-07-21 09:18:48

Windows 10Windows 8性能

2023-05-12 07:38:46

Python基準測試性能分析

2020-10-23 14:05:39

AI 服務器測試

2011-09-22 13:49:44

XML基準測試

2009-06-23 15:51:00

JSF框架
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 国产欧美一区二区三区日本久久久 | 91极品尤物在线播放国产 | 久久99精品久久久久久青青日本 | 免费三级av | 久草电影网 | 91免费视频观看 | 精品欧美一区二区在线观看欧美熟 | 2021狠狠干 | 范冰冰一级做a爰片久久毛片 | 中文字幕av一区 | 蜜臀网| 日韩精品国产精品 | 欧美午夜精品久久久久久浪潮 | 欧美精品中文 | 亚洲一区二区三区在线视频 | 国产男女精品 | 爱操影视 | 黄网站在线观看 | 国家aaa的一级看片 h片在线看 | 中文字幕视频在线看5 | 一区二区在线免费观看 | 九色 在线| 午夜精品一区二区三区三上悠亚 | 日日夜夜免费精品视频 | 国产免费一区二区 | 国产精品欧美精品日韩精品 | 99re视频这里只有精品 | 久久一区二区免费视频 | 中文字幕视频网 | 日韩在线免费播放 | 久久久久久影院 | 亚洲一区久久久 | 一区二区三区免费 | 亚洲a一区 | 999精品在线观看 | 久久久夜 | 国产精品一区二区无线 | 精品一区国产 | 日韩中文不卡 | av网站免费观看 | 三级成人片 |