freepeople性欧美熟妇, 色戒完整版无删减158分钟hd, 无码精品国产vα在线观看DVD, 丰满少妇伦精品无码专区在线观看,艾栗栗与纹身男宾馆3p50分钟,国产AV片在线观看,黑人与美女高潮,18岁女RAPPERDISSSUBS,国产手机在机看影片

正文內容

petshop的系統(tǒng)架構設計(編輯修改稿)

2024-07-26 18:28 本頁面
 

【文章內容簡介】 using (TransactionScope ts = new TransactionScope(, tsTimeout)) { // Receive the orders from the queue for (int j = 0。 j batchSize。 j++) { try { //only receive more queued orders if there is enough time if ((elapsedTime + queueTimeout + transactionTimeout) ) { ((queueTimeout))。 } else { j = batchSize。 // exit loop } //update elapsed time elapsedTime = new TimeSpan().TotalSeconds 。 } catch (TimeoutException) { //exit loop because no more messages are waiting j = batchSize。 } } //process the queued orders for (int k = 0。 k 。 k++) { ((OrderInfo)queueOrders[k])。 processedItems++。 totalOrdersProcessed++。 } //batch plete or MSMQ receive timed out ()。 } ((Thread Id + + ) batch finished, + processedItems + items, in + () + seconds.)。 } } 首先,()來獲取消息隊列中的訂單數(shù)據(jù),并將其放入到一個ArrayList對象中。 ,并不是直接執(zhí)行插入訂單的操作,而是調用了IOrderStrategy接口的Insert()方法:public void Insert(OrderInfo order){ // Call credit card procesor ProcessCreditCard(order)。 // Insert the order (a)synchrounously based on configuration (order)。} 在這里,運用了一個策略模式,類圖如下所示: ,仍然利用配置文件來動態(tài)創(chuàng)建IOrderStategy對象:private static readonly orderInsertStrategy = LoadInsertStrategy()。private static LoadInsertStrategy(){ // Look up which strategy to use from config file string path = [”O(jiān)rderStrategyAssembly”]。 string className = [”O(jiān)rderStrategyClass”]。 // Using the evidence given in the config file load the appropriate assembly and class return ()(path).CreateInstance(className)。} 由于OrderProcessor是一個單獨的應用程序,因此它使用的配置文件與PetShop不同,在該文件中,對IOrderStategy的配置為: add key=”O(jiān)rderStrategyAssembly” value=”” / add key=”O(jiān)rderStrategyClass” value=”” / 因此,以異步方式插入訂單的流程如下圖所示: Microsoft Messaging Queue(MSMQ)技術除用于異步處理以外,它主要還是一種分布式處理技術。分布式處理中,一個重要的技術要素就是有關消息的處理,已經(jīng)提供了Message類,可以用于承載消息的傳遞,前提上消息的發(fā)送方與接收方在數(shù)據(jù)定義上應有統(tǒng)一的接口規(guī)范。 MSMQ在分布式處理的運用,在我參與的項目中已經(jīng)有了實現(xiàn)。在為一個汽車制造商開發(fā)一個大型系統(tǒng)時,需要將數(shù)據(jù)傳遞到管理中心,并且該數(shù)據(jù)將被Oracle的EBS(EBusiness System)使用。由于分銷商管理系統(tǒng)(DMS)采用的是C/S結構,數(shù)據(jù)庫為SQL Server,而汽車制造商管理中心的EBS數(shù)據(jù)庫為Oracle。這里就涉及到兩個系統(tǒng)之間數(shù)據(jù)的傳遞。 實現(xiàn)架構如下: 首先Dealer的數(shù)據(jù)通過MSMQ傳遞到MSMQ Server,此時可以將數(shù)據(jù)插入到SQL Server數(shù)據(jù)庫中,同時利用FTP將數(shù)據(jù)傳送到專門的文件服務器上。然后利用IBM的EAI技術(企業(yè)應用集成,Enterprise Application Itegration)定期將文件服務器中的文件,利用接口規(guī)范寫入到EAI數(shù)據(jù)庫服務器中,并最終寫道EBS的Oracle數(shù)據(jù)庫中。 上述架構是一個典型的分布式處理結構,而技術實現(xiàn)的核心就是MSMQ和EAI。由于我們已經(jīng)定義了統(tǒng)一的接口規(guī)范,在通過消息隊列形成文件后,此時的數(shù)據(jù)就已經(jīng)與平臺無關了,完成數(shù)據(jù)的處理。 Filed under: Design amp。 Pattern — bruce zhang @ 6:20 pm 《解剖PetShop》系列之四四 如果對微型計算機硬件系統(tǒng)有足夠的了解,那么我們對于Cache這個名詞一定是耳熟能詳?shù)?。在CPU以及主板的芯片中,都引入了這種名為高速緩沖存儲器(Cache)的技術。因為Cache的存取速度比內存快,因而引入Cache能夠有效的解決CPU與內存之間的速度不匹配問題。硬件系統(tǒng)可以利用Cache存儲CPU訪問概率高的那些數(shù)據(jù),當CPU需要訪問這些數(shù)據(jù)時,可以直接從Cache中讀取,而不必訪問存取速度相對較慢的內存,從而提高了CPU的工作效率。軟件設計借鑒了硬件設計中引入緩存的機制以改善整個系統(tǒng)的性能,尤其是對于一個數(shù)據(jù)庫驅動的Web應用程序而言,緩存的利用是不可或缺的,畢竟,數(shù)據(jù)庫查詢可能是整個Web站點中調用最頻繁但同時又是執(zhí)行最緩慢的操作之一,我們不能被它老邁的雙腿拖緩我們前進的征程。緩存機制正是解決這一缺陷的加速器。 。通過某種方法,將系統(tǒng)需要的數(shù)據(jù)對象、Web頁面存儲在內存中,使得Web站點在需要獲取這些數(shù)據(jù)時,不需要經(jīng)過繁瑣的數(shù)據(jù)庫連接、查詢和復雜的邏輯運算,就可以“觸手可及”,如“探囊取物”般容易而快速,從而提高整個Web系統(tǒng)的性能。一種是應用程序緩存,它允許開發(fā)者將程序生成的數(shù)據(jù)或報表業(yè)務對象放入緩存中。另外一種緩存機制是頁輸出緩存,利用它,可以直接獲取存放在緩存中的頁面,而不需要經(jīng)過繁雜的對該頁面的再次處理。應用程序緩存其實現(xiàn)原理說來平淡無奇。放入緩存中的應用程序數(shù)據(jù)對象,以鍵/值對的方式存儲,這便于用戶在訪問緩存中的數(shù)據(jù)項時,可以根據(jù)key值判斷該項是否存在緩存中。放入在緩存中的數(shù)據(jù)對象其生命周期是受到限制的,即使在整個應用程序的生命周期里,也不能保證該數(shù)據(jù)對象一直有效。,例如當數(shù)據(jù)項無效、過期或內存不足時移除它們。此外,調用者還可以通過CacheItemRemovedCallback委托,定義回調方法使得數(shù)據(jù)項被移除時能夠通知用戶。 Framework中。它是一個密封類,不能被繼承。對于每一個應用程序域,都要創(chuàng)建一個Cache類的實例,其生命周期與應用程序域的生命周期保持一致。我們可以利用Add或Insert方法,將數(shù)據(jù)項添加到應用程序緩存中,如下所示:Cache[”First”] = “First Item”。(”Second”, “Second Item”)。我們還可以為應用程序緩存添加依賴項,使得依賴項發(fā)生更改時,該數(shù)據(jù)項能夠從緩存中移除:string[] dependencies = {”Second”}。(”Third”, “Third Item”,new (null, dependencies))。與之對應的是緩存中數(shù)據(jù)項的移除。,但我們也可以通過代碼編寫的方式顯式的移除相關的數(shù)據(jù)項:(”First”)。相對于應用程序緩存而言,頁輸出緩存的應用更為廣泛。,當客戶端再一次訪問該頁面時,可以省去頁面處理的過程,從而提高頁面訪問的性能,以及Web服務器的吞吐量。例如,在一個電子商務網(wǎng)站里,用戶需要經(jīng)常查詢商品信息,這個過程會涉及到數(shù)據(jù)庫訪問以及搜索條件的匹配,在數(shù)據(jù)量較大的情況下,如此的搜索過程是較為耗時的。此時,利用頁輸出緩存就可以將第一次搜索得到的查詢結果頁存儲在緩存中。當用戶第二次查詢時,就可以省去數(shù)據(jù)查詢的過程,減少頁面的響應時間。頁輸出緩存分為整頁緩存和部分頁緩存。我們可以通過@OutputCache指令完成對Web頁面的輸出緩存。它主要包含兩個參數(shù):Duration和VaryByParam。Duration參數(shù)用于設置頁面或控件進行緩存的時間,其單位為秒。如下的設置表示緩存在60秒內有效: %@ OutputCache Duration=“60“ VaryByParam=“none“ %只要沒有超過Duration設置的期限值,當用戶訪問相同的頁面或控件時,就可以直接在緩存中獲取。使用VaryByParam參數(shù)可以根據(jù)設置的參數(shù)值建立不同的緩存。例如在一個輸出天氣預報結果的頁面中,如果需要為一個ID為txtCity的TextBox控件建立緩存,其值將顯示某城市的氣溫,那么我們可以進行如下的設置: %@ OutputCache
點擊復制文檔內容
范文總結相關推薦
文庫吧 www.dybbs8.com
備案圖片鄂ICP備17016276號-1