TWI804860B - 用於使區域快取同步的電腦實行系統以及方法 - Google Patents
用於使區域快取同步的電腦實行系統以及方法 Download PDFInfo
- Publication number
- TWI804860B TWI804860B TW110116243A TW110116243A TWI804860B TW I804860 B TWI804860 B TW I804860B TW 110116243 A TW110116243 A TW 110116243A TW 110116243 A TW110116243 A TW 110116243A TW I804860 B TWI804860 B TW I804860B
- Authority
- TW
- Taiwan
- Prior art keywords
- server
- remote
- remote server
- computer
- local cache
- Prior art date
Links
Images
Classifications
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F12/00—Accessing, addressing or allocating within memory systems or architectures
- G06F12/02—Addressing or allocation; Relocation
- G06F12/08—Addressing or allocation; Relocation in hierarchically structured memory systems, e.g. virtual memory systems
- G06F12/0802—Addressing of a memory level in which the access to the desired data or data block requires associative addressing means, e.g. caches
- G06F12/0806—Multiuser, multiprocessor or multiprocessing cache systems
- G06F12/0815—Cache consistency protocols
- G06F12/0831—Cache consistency protocols using a bus scheme, e.g. with bus monitoring or watching means
- G06F12/0833—Cache consistency protocols using a bus scheme, e.g. with bus monitoring or watching means in combination with broadcast means (e.g. for invalidation or updating)
-
- G—PHYSICS
- G06—COMPUTING; CALCULATING OR COUNTING
- G06F—ELECTRIC DIGITAL DATA PROCESSING
- G06F16/00—Information retrieval; Database structures therefor; File system structures therefor
- G06F16/90—Details of database functions independent of the retrieved data types
- G06F16/95—Retrieval from the web
- G06F16/957—Browsing optimisation, e.g. caching or content distillation
- G06F16/9574—Browsing optimisation, e.g. caching or content distillation of access to content, e.g. by caching
-
- H—ELECTRICITY
- H04—ELECTRIC COMMUNICATION TECHNIQUE
- H04W—WIRELESS COMMUNICATION NETWORKS
- H04W24/00—Supervisory, monitoring or testing arrangements
- H04W24/08—Testing, supervising or monitoring using real traffic
Landscapes
- Engineering & Computer Science (AREA)
- Theoretical Computer Science (AREA)
- Physics & Mathematics (AREA)
- General Engineering & Computer Science (AREA)
- General Physics & Mathematics (AREA)
- Databases & Information Systems (AREA)
- Data Mining & Analysis (AREA)
- Computer Networks & Wireless Communication (AREA)
- Signal Processing (AREA)
- Management, Administration, Business Operations System, And Electronic Commerce (AREA)
- Information Transfer Between Computers (AREA)
- Mathematical Physics (AREA)
- Information Retrieval, Db Structures And Fs Structures Therefor (AREA)
- Memory System Of A Hierarchy Structure (AREA)
- Mobile Radio Communication Systems (AREA)
Abstract
本發明揭露一種用於使區域快取同步的電腦實行方法。方
法可包含接收內容更新,內容更新為對儲存於多個遠端伺服器中的每一者的區域快取中的資料項的更新。方法可包含將內容更新傳輸至第一遠端伺服器以更新第一遠端伺服器的區域快取中的對應資料項。另外,方法可包含產生無效命令,從而指示對應資料項的改變。方法可包含將無效命令自第一遠端伺服器傳輸至訊息伺服器。方法可包含由訊息伺服器基於接收到的無效命令產生多個分區。方法可包含將多個分區自訊息伺服器傳輸至遠端伺服器中的每一者,使得遠端伺服器更新其各別區域快取。
Description
本揭露內容大體上是關於用於使區域快取同步的電腦化系統及方法。特定而言,本揭露內容的實施例是關於基於對遠端伺服器中的一些的區域快取中的一或多者的更新使多個遠端伺服器的區域快取高效同步的發明性及非習知系統。
在線上零售商業領域中,與各種產品相關的資訊儲存於資料庫中。當購物者瀏覽線上零售商業的顯示介面(諸如網頁)時,伺服器系統自資料庫取回此資訊以向購物者顯示。此外,基於所顯示物件,購物者可與所顯示介面交互以針對物件下訂單。
支援與線上零售系統的前述交互的各種程式及應用程式可由遠端伺服器執行。舉例而言,由於線上零售系統必須支援與許多購物者的交互,故單一電腦伺服器可能不能夠實際上支援所有必要功能。因此,可以使得彼等功能分佈於不同伺服器當中的方式利用多個伺服器。此等多個伺服器可稱為遠端伺服器。因此,一些購物者可經由一個遠端伺服器與線上零售系統交互,而其他購物者可經由另一遠端伺服器與線上零售系統交互。
不管需要多少遠端伺服器以支援所述數個購物者,不同
遠端伺服器均應自購物者的視角相同地起作用。亦即,與線上零售系統交互的購物者不應基於哪一遠端伺服器正支援所述交互而經歷任何不同。舉例而言,產品清單、促銷、檢索結果及/或其他產品或購物相關資訊或功能應在由購物者查看時在所有遠端伺服器上為相同的。
習知方法及系統使用一或多個集中式資料庫將資料供應至遠端伺服器,使得不同遠端伺服器均存取相同資料。此外,可藉由更新集中式資料庫對線上零售系統作出改變,且所有遠端伺服器將可存取更新後的資料。然而,習知方法及系統可導致高網路訊務,尤其在遠端伺服器需要自集中式資料庫不斷提取資料的情況下。高網路訊務又可能導致延遲,減輕延遲可能需要昂貴硬體基礎架構。
本揭露內容的一個態樣是針對一種用於使區域快取同步的電腦實行系統,包括:一或多個處理器;至少一個記憶體儲存裝置,儲存指令,所述指令在由所述一或多個處理器執行時進行包括下述者的操作:接收內容更新,所述內容更新為對儲存於多個遠端伺服器中的每一者的區域快取中的資料項的更新;將所述內容更新傳輸至所述遠端伺服器中的第一遠端伺服器以更新所述第一遠端伺服器的區域快取中的對應資料項;向訊息伺服器產生無效命令,所述無效命令經組態以指示所述第一遠端伺服器的所述區域快取中的所述對應資料項的改變;將所述無效命令自所述第一遠端伺服器傳輸至所述訊息伺服器;由所述訊息伺服器基於接收到
的無效命令產生多個分區;將所述多個分區自所述訊息伺服器傳輸至所述遠端伺服器中的每一者,其中所述多個分區使得所述遠端伺服器更新其各別區域快取。
本揭露內容的另一態樣是針對一種用於使區域快取同步的電腦實行方法,包括:接收內容更新,所述內容更新為對儲存於多個遠端伺服器中的每一者的區域快取中的資料項的更新;將所述內容更新傳輸至所述遠端伺服器中的第一遠端伺服器以更新所述第一遠端伺服器的區域快取中的對應資料項;向訊息伺服器產生無效命令,所述無效命令經組態以指示所述第一遠端伺服器的所述區域快取中的所述對應資料項的改變;將所述無效命令自所述第一遠端伺服器傳輸至所述訊息伺服器;由所述訊息伺服器基於接收到的無效命令產生多個分區;將所述多個分區自所述訊息伺服器傳輸至所述遠端伺服器中的每一者,其中所述多個分區使得所述遠端伺服器更新其各別區域快取。
本揭露內容的又一態樣是針對一種用於使區域快取同步的電腦實行系統,包括:一或多個處理器;至少一個記憶體儲存裝置,儲存指令,所述指令在由所述一或多個處理器執行時進行包括下述者的操作:接收內容更新,所述內容更新為移除儲存於多個遠端伺服器的區域快取中的資料項的命令;將所述內容更新傳輸至所述遠端伺服器中的第一遠端伺服器以移除所述第一遠端伺服器的所述區域快取中的對應資料項;向訊息伺服器產生無效命令,所述無效命令經組態以移除所述第一遠端伺服器的所述區域快取中的所述對應資料項;將所述無效命令自所述第一遠端伺服器傳輸至訊息伺服器,所述訊息伺服器為串流處理伺服器;由所述訊息伺
服器產生多個分區,所述分區中的每一者包含所述無效命令的複本;將所述分區自所述訊息伺服器傳輸至所述遠端伺服器,其中所述分區使得所述遠端伺服器移除其各別區域快取中的對應資料項。
本文中亦論述其他系統、方法以及電腦可讀媒體。
100、300:系統
101:運送授權技術系統
102A:行動裝置/使用者裝置
102B:電腦/使用者裝置
103:外部前端系統
105:內部前端系統
107:運輸系統
107A、107B、107C:行動裝置
109:賣方入口網站
111:運送及訂單追蹤系統
113:履行最佳化系統
115:履行通信報閘道
117:供應鏈管理系統
119:倉庫管理系統
119A:行動裝置/平板電腦
119B:行動裝置/PDA
119C:行動裝置/電腦
121A、121B、121C:第3方履行系統
123:履行中心授權系統
125:勞動管理系統
200:履行中心
201、222:卡車
202A、202B、208:物件
203:入站區
205:緩衝區
206:叉車
207:卸貨區
209:揀貨區
210:儲存單元
211:包裝區
213:樞紐區
214:運輸機構
215:營地區
216:牆
218、220:包裹
224A、224B:遞送工作者
226:汽車
302:中央資料庫/集中式資料庫
304a、304b、304c、304d、304m:區域快取
306a、306b、306c、306d、306m:遠端伺服器
308:客戶
400:過程
402:伺服器
404:訊息伺服器
502:資料/更新訊息/無效命令
504、504a、504b、504n:分區
600:過程
602、604、606、608、610、612、614:步驟
I-1、I-2、I-3:子組件
圖1A為與所揭露實施例一致的示出包括用於實現運送、運輸以及物流操作的通信的電腦化系統的網路的例示性實施例的示意性方塊圖。
圖1B描繪與所揭露實施例一致的包含滿足檢索請求的一或多個檢索結果以及交互式使用者介面元素的樣本檢索結果頁(Search Result Page;SRP)。
圖1C描繪與所揭露實施例一致的包含產品及關於所述產品的資訊以及交互式使用者介面元素的樣本單一詳情頁(Single Detail Page;SDP)。
圖1D描繪與所揭露實施例一致的包含虛擬購物車中的物件以及交互式使用者介面元素的樣本購物車頁。
圖1E描繪與所揭露實施例一致的包含來自虛擬購物車的物件以及關於購買及運送的資訊以及交互式使用者介面元素的樣本訂單頁。
圖2為與所揭露實施例一致的經組態以利用所揭露電腦化系統的例示性履行中心的圖解圖示。
圖3為與所揭露實施例一致的包含多個遠端伺服器及區域快取的例示性系統的示意圖。
圖4為展示與所揭露實施例一致的用於基於內容更新來更新區域快取的例示性過程的示意圖。
圖5為與所揭露實施例一致的去至多個遠端伺服器的例示性分區傳播的示意圖。
圖6描繪與所揭露實施例一致的用於使區域快取同步的例示性過程的流程圖。
以下詳細描述參考隨附圖式。只要可能,即在圖式及以下描述中使用相同附圖標號來指代相同或類似部分。儘管本文中描述若干示出性實施例,但修改、調適以及其他實施方案是可能的。舉例而言,可對圖式中所示出的組件及步驟進行替代、添加或修改,且可藉由取代、重新排序、移除步驟或將步驟添加至所揭露方法來修改本文中所描述的示出性方法。因此,以下詳細描述不限於所揭露實施例及實例。實情為,本發明的正確範圍由隨附申請專利範圍界定。
參考圖1A,繪示示出包括用於實現運送、運輸以及物流操作的通信的電腦化系統的系統的例示性實施例的示意性方塊圖100。如圖1A中所示出,系統100可包含各種系統,所述系統中的每一者可經由一或多個網路彼此連接。所述系統亦可經由直接連接(例如,使用電纜)彼此連接。所描繪系統包含運送授權技術(shipment authority technology;SAT)系統101、外部前端系統103、
內部前端系統105、運輸系統107、行動裝置107A、行動裝置107B以及行動裝置107C、賣方入口網站109、運送及訂單追蹤(shipment and order tracking;SOT)系統111、履行最佳化(fulfillment optimization;FO)系統113、履行通信報閘道(fulfillment messaging gateway;FMG)115、供應鏈管理(supply chain management;SCM)系統117、倉庫管理系統119、行動裝置119A、行動裝置119B以及行動裝置119C(描繪為位於履行中心(fulfillment center;FC)200內部)、第3方履行系統121A、第3方履行系統121B以及第3方履行系統121C、履行中心授權系統(fulfillment center authorization;FC Auth)123以及勞動管理系統(labor management system;LMS)125。
在一些實施例中,SAT系統101可實行為監視訂單狀態及遞送狀態的電腦系統。舉例而言,SAT系統101可判定訂單是否超過其承諾遞送日期(PDD)且可採取適當的動作,包含發起新訂單、對未遞送訂單中的物件進行重新運送、取消未遞送訂單、發起與訂購客戶的連絡,或類似者。SAT系統101亦可監視其他資料,包含輸出(諸如在特定時段期間運送的包裹的數目)及輸入(諸如接收到的用於運送的空紙板盒的數目)。SAT系統101亦可充當系統100中的不同裝置之間的閘道,從而(例如,使用儲存及轉發或其他技術)實現諸如外部前端系統103及FO系統113的裝置之間的通信。
在一些實施例中,外部前端系統103可實行為使得外部使用者能夠與系統100中的一或多個系統交互的電腦系統。舉例而言,在系統100使得系統的呈現能夠允許使用者針對物件下訂
單的實施例中,外部前端系統103可實行為接收檢索請求、呈現物件頁以及索求支付資訊的網頁伺服器。舉例而言,外部前端系統103可實行為電腦或電腦運行軟體,諸如阿帕奇(Apache)HTTP伺服器、微軟網際網路資訊服務(Internet Information Service;IIS)、NGINX,或類似者。在其他實施例中,外部前端系統103可運行經設計以接收及處理來自外部裝置(例如,行動裝置102A或電腦102B)的請求、基於彼等請求自資料庫及其他資料儲存庫獲取資訊,以及基於所獲取的資訊將回應提供至接收到的請求的定製網頁伺服器軟體。
在一些實施例中,外部前端系統103可包含網頁快取系統、資料庫、檢索系統或支付系統中的一或多者。在一個態樣中,外部前端系統103可包括此等系統中的一或多者,而在另一態樣中,外部前端系統103可包括連接至此等系統中的一或多者的介面(例如,伺服器至伺服器、資料庫至資料庫,或其他網路連接)。
藉由圖1B、圖1C、圖1D以及圖1E所示出的例示性步驟集合將有助於描述外部前端系統103的一些操作。外部前端系統103可自系統100中的系統或裝置接收資訊以供呈現及/或顯示。舉例而言,外部前端系統103可代管或提供一或多個網頁,包含檢索結果頁(SRP)(例如,圖1B)、單一詳情頁(Single Detail Page;SDP)(例如,圖1C)、購物車頁(例如,圖1D),或訂單頁(例如,圖1E)。(例如,使用行動裝置102A或電腦102B的)使用者裝置可導航至外部前端系統103且藉由將資訊輸入至檢索盒中來請求檢索。外部前端系統103可向系統100中的一或多個系統請求資訊。舉例而言,外部前端系統103可向FO系統113請求
滿足檢索請求的資訊。外部前端系統103亦可(自FO系統113)請求及接收包含於檢索結果中的每一產品的承諾遞送日期或「PDD」。在一些實施例中,PDD可表示在特定時段內(例如,在一天結束(下午11:59)前)訂購的情況下對含有產品的包裹將何時抵達使用者的所要位置或承諾將產品遞送至使用者的所要位置處的日期的估計。(PDD在下文相對於FO系統113進一步論述。)
外部前端系統103可基於資訊來準備SRP(例如,圖1B)。SRP可包含滿足檢索請求的資訊。舉例而言,此可包含滿足檢索請求的產品的圖像。SRP亦可包含每一產品的各別價格,或與每一產品的增強遞送選項、PDD、重量、大小、報價、折扣或類似者相關的資訊。外部前端系統103可(例如,經由網路)將SRP發送至請求使用者裝置。
使用者裝置可接著例如藉由點選或輕觸使用者介面或使用另一輸入裝置自SRP選擇產品,以選擇表示於SRP上的產品。使用者裝置可製訂對關於所選產品的資訊的請求且將其發送至外部前端系統103。作為回應,外部前端系統103可請求與所選產品相關的資訊。舉例而言,資訊可包含除針對各別SRP上的產品呈現的資訊以外的額外資訊。此可包含例如保存期限、原產國、重量、大小、包裹中的物件的數目、處置說明,或關於產品的其他資訊。資訊亦可包含類似產品的推薦(基於例如巨量資料及/或對購買此產品及至少一個其他產品的客戶的機器學習分析)、頻繁詢問的問題的答案、來自客戶的評論、製造商資訊、圖像,或類似者。
外部前端系統103可基於接收到的產品資訊來準備SDP(單一詳情頁)(例如,圖1C)。SDP亦可包含其他交互式元素,諸
如「現在購買」按鈕、「添加至購物車」按鈕、數量欄位、物件的圖像,或類似者。SDP可更包含提供產品的賣方的清單。可基於每一賣方提供的價格來對清單進行排序,使得可在頂部處列出提供以最低價格出售產品的賣方。亦可基於賣方排名來對清單進行排序,使得可在頂部處列出排名最高的賣方。可基於多個因素來製訂賣方排名,所述因素包含例如賣方的符合承諾PDD的過去的追蹤記錄。外部前端系統103可(例如,經由網路)將SDP遞送至請求使用者裝置。
請求使用者裝置可接收列出產品資訊的SDP。在接收到SDP後,使用者裝置可接著與SDP交互。舉例而言,請求使用者裝置的使用者可點選或以其他方式與SDP上的「放在購物車中」按鈕交互。此將產品添加至與使用者相關聯的購物車。使用者裝置可將把產品添加至購物車的此請求傳輸至外部前端系統103。
外部前端系統103可產生購物車頁(例如,圖1D)。在一些實施例中,購物車頁列出使用者已添加至虛擬「購物車」的產品。使用者裝置可藉由在SRP、SDP或其他頁上的圖標上點選或以其他方式與所述圖標交互來請求購物車頁。在一些實施例中,購物車頁可列出使用者已添加至購物車的所有產品,以及關於購物車中的產品的資訊(諸如每一產品的數量、每一產品每物件的價格、每一產品基於相關聯數量的價格)、關於PDD的資訊、遞送方法、運送成本、用於修改購物車中的產品(例如,刪除或修改數量)的使用者介面元素、用於訂購其他產品或設置產品的定期遞送的選項、用於設置利息支付的選項、用於前進至購買的使用者介面元素,或類似者。使用者裝置處的使用者可在使用者介面元素(例
如,寫著「現在購買」的按鈕)上點選或以其他方式與所述使用者介面元素交互,以發起對購物車中的產品的購買。在如此做後,使用者裝置可將發起購買的此請求傳輸至外部前端系統103。
外部前端系統103可回應於接收到發起購買的請求而產生訂單頁(例如,圖1E)。在一些實施例中,訂單頁重新列出來自購物車的物件且請求支付及運送資訊的輸入。舉例而言,訂單頁可包含請求關於購物車中的物件的購買者的資訊(例如,姓名、地址、電子郵件地址、電話號碼)、關於接收者的資訊(例如,姓名、地址、電話號碼、遞送資訊)、運送資訊(例如,遞送及/或揀貨的速度/方法)、支付資訊(例如,信用卡、銀行轉賬、支票、儲存的積分)的部分、請求現金收據(例如,出於稅務目的)的使用者介面元素,或類似者。外部前端系統103可將訂單頁發送至使用者裝置。
使用者裝置可輸入關於訂單頁的資訊,且點選或以其他方式與將資訊發送至外部前端系統103的使用者介面元素交互。自此處,外部前端系統103可將資訊發送至系統100中的不同系統,以使得能夠創建及處理具有購物車中的產品的新訂單。
在一些實施例中,外部前端系統103可進一步經組態以使得賣方能夠傳輸及接收與訂單相關的資訊。
在一些實施例中,內部前端系統105可實行為使得內部使用者(例如,擁有、操作或租用系統100的組織的雇員)能夠與系統100中的一或多個系統交互的電腦系統。舉例而言,在系統100使得系統的呈現能夠允許使用者針對物件下訂單的實施例中,內部前端系統105可實行為使得內部使用者能夠查看關於訂單的
診斷及統計資訊、修改物件資訊或審查與訂單相關的統計的網頁伺服器。舉例而言,內部前端系統105可實行為電腦或電腦運行軟體,諸如阿帕奇HTTP伺服器、微軟(Microsoft)網際網路資訊服務(IIS)、NGINX,或類似者。在其他實施例中,內部前端系統105可運行經設計以接收及處理來自系統100中所描繪的系統或裝置(以及未描繪的其他裝置)的請求、基於彼等請求自資料庫及其他資料儲存庫獲取資訊,以及基於所獲取的資訊來將回應提供至接收到的請求的定製網頁伺服器軟體。
在一些實施例中,內部前端系統105可包含網頁快取系統、資料庫、檢索系統、支付系統、分析系統、訂單監視系統或類似者中的一或多者。在一個態樣中,內部前端系統105可包括此等系統中的一或多者,而在另一態樣中,內部前端系統105可包括連接至此等系統中的一或多者的介面(例如,伺服器至伺服器、資料庫至資料庫,或其他網路連接)。
在一些實施例中,運輸系統107可實行為實現系統100中的系統或裝置與行動裝置107A至行動裝置107C之間的通信的電腦系統。在一些實施例中,運輸系統107可自一或多個行動裝置107A至行動裝置107C(例如,行動電話、智慧型電話、PDA,或類似者)接收資訊。舉例而言,在一些實施例中,行動裝置107A至行動裝置107C可包括由遞送工作者操作的裝置。遞送工作者(其可為永久雇員、暫時雇員或輪班雇員)可利用行動裝置107A至行動裝置107C來實現對含有由使用者訂購的產品的包裹的遞送。舉例而言,為遞送包裹,遞送工作者可在行動裝置上接收指示遞送哪一包裹及將所述包裹遞送到何處的通知。在抵達遞送位置
後,遞送工作者可(例如,在卡車的後部中或在包裹的條板箱中)定位包裹、使用行動裝置掃描或以其他方式擷取與包裹上的識別符(例如,條碼、影像、文字字串、RFID標籤,或類似者)相關聯的資料,且遞送包裹(例如,藉由將其留在前門處、將其留給警衛、將其交給接收者,或類似者)。在一些實施例中,遞送工作者可使用行動裝置擷取包裹的相片及/或可獲得簽名。行動裝置可將資訊發送至運輸系統107,所述資訊包含關於遞送的資訊,包含例如時間、日期、GPS位置、相片、與遞送工作者相關聯的識別符、與行動裝置相關聯的識別符,或類似者。運輸系統107可在資料庫(未描繪)中儲存此資訊以用於由系統100中的其他系統存取。在一些實施例中,運輸系統107可使用此資訊來準備追蹤資料且將所述追蹤資料發送至其他系統,從而指示特定包裹的位置。
在一些實施例中,某些使用者可使用一個種類的行動裝置(例如,永久工作者可使用具有定製硬體(諸如條碼掃描器、尖筆以及其他裝置)的專用PDA),而其他使用者可使用其他類型的行動裝置(例如,暫時工作者或輪班工作者可利用現成的行動電話及/或智慧型電話)。
在一些實施例中,運輸系統107可使使用者與每一裝置相關聯。舉例而言,運輸系統107可儲存使用者(由例如使用者識別符、雇員識別符或電話號碼表示)與行動裝置(由例如國際行動設備身分(International Mobile Equipment Identity;IMEI)、國際行動訂用識別符(International Mobile Subscription Identifier;IMSI)、電話號碼、通用唯一識別符(Universal Unique Identifier;UUID)或全球唯一識別符(Globally Unique Identifier;GUID)表
示)之間的關聯。運輸系統107可結合在遞送時接收到的資料使用此關聯來分析儲存於資料庫中的資料,以便尤其判定工作者的位置、工作者的效率,或工作者的速度。
在一些實施例中,賣方入口網站109可實行為使得賣方或其他外部實體能夠與系統100中的一或多個系統電子地通信的電腦系統。舉例而言,賣方可利用電腦系統(未描繪)來上載或提供賣方希望經由使用賣方入口網站109的系統100來出售的產品的產品資訊、訂單資訊、連絡資訊或類似者。
在一些實施例中,運送及訂單追蹤系統111可實行為接收、儲存以及轉送關於含有由客戶(例如,由使用裝置102A至裝置102B的使用者)訂購的產品的包裹的位置的資訊的電腦系統。在一些實施例中,運送及訂單追蹤系統111可請求或儲存來自由遞送含有由客戶訂購的產品的包裹的運送公司操作的網頁伺服器(未描繪)的資訊。
在一些實施例中,運送及訂單追蹤系統111可請求及儲存來自在系統100中描繪的系統的資訊。舉例而言,運送及訂單追蹤系統111可請求來自運輸系統107的資訊。如上文所論述,運輸系統107可自與使用者(例如,遞送工作者)或車輛(例如,遞送卡車)中的一或多者相關聯的一或多個行動裝置107A至行動裝置107C(例如,行動電話、智慧型電話、PDA或類似者)接收資訊。在一些實施例中,運送及訂單追蹤系統111亦可向倉庫管理系統(warehouse management system;WMS)119請求資訊以判定個別產品在履行中心(例如,履行中心200)內部的位置。運送及訂單追蹤系統111可向運輸系統107或WMS 119中的一或多者
請求資料,在請求後處理所述資料,且將所述資料呈現給裝置(例如,使用者裝置102A及使用者裝置102B)。
在一些實施例中,履行最佳化(FO)系統113可實行為儲存來自其他系統(例如,外部前端系統103及/或運送及訂單追蹤系統111)的客戶訂單的資訊的電腦系統。FO系統113亦可儲存描述特定物件保存或儲存於何處的資訊。舉例而言,某些物件可能僅儲存於一個履行中心中,而某些其他物件可能儲存於多個履行中心中。在再其他實施例中,某些履行中心可經設計以僅儲存特定物件集合(例如,新鮮生產或冷凍的產品)。FO系統113儲存此資訊以及相關聯資訊(例如,數量、大小、接收日期、過期日期等)。
FO系統113亦可計算每一產品的對應PDD(承諾遞送日期)。在一些實施例中,PDD可以基於一或多個因素。舉例而言,FO系統113可基於下述者來計算產品的PDD:對產品的過去需求(例如,在一段時間期間訂購了多少次所述產品)、對產品的預期需求(例如,預報在即將到來的一段時間期間多少客戶將訂購所述產品)、指示在一段時間期間訂購了多少產品的全網路過去需求、指示預期在即將到來的一段時間期間將訂購多少產品的全網路預期需求、儲存於每一履行中心200中的產品的一或多個計數、哪一履行中心儲存每一產品、產品的預期或當前訂單,或類似者。
在一些實施例中,FO系統113可定期(例如,每小時)判定每一產品的PDD且將其儲存於資料庫中以供取回或發送至其他系統(例如,外部前端系統103、SAT系統101、運送及訂單追蹤系統111)。在其他實施例中,FO系統113可自一或多個系統(例如,外部前端系統103、SAT系統101、運送及訂單追蹤系統
111)接收電子請求且按需求計算PDD。
在一些實施例中,履行通信報閘道(FMG)115可實行為自系統100中的一或多個系統(諸如FO系統113)接收呈一種格式或協定的請求或回應、將其轉換為另一格式或協定且將其以轉換後的格式或協定轉發至其他系統(諸如WMS 119或第3方履行系統121A、第3方履行系統121B或第3方履行系統121C)且反之亦然的電腦系統。
在一些實施例中,供應鏈管理(SCM)系統117可實行為進行預報功能的電腦系統。舉例而言,SCM系統117可基於例如下述者來預報對特定產品的需求水平:對產品的過去需求、對產品的預期需求、全網路過去需求、全網路預期需求、儲存於每一履行中心200中的計數產品、每一產品的預期或當前訂單,或類似者。回應於此預報水平及所有履行中心中的每一產品的量,SCM系統117可產生一或多個購買訂單以購買及儲備足夠數量,以滿足對特定產品的預報需求。
在一些實施例中,倉庫管理系統(WMS)119可實行為監視工作流程的電腦系統。舉例而言,WMS 119可自個別裝置(例如,裝置107A至裝置107C或裝置119A至裝置119C)接收指示離散事件的事件資料。舉例而言,WMS 119可接收指示使用此等裝置中的一者掃描包裹的事件資料。如下文相對於履行中心200及圖2所論述,在履行過程期間,可藉由特定階段處的機器(例如,自動式或手持式條碼掃描器、RFID讀取器、高速攝影機、諸如平板電腦119A、行動裝置/PDA 119B、電腦119C的裝置或類似者)掃描或讀取包裹識別符(例如,條碼或RFID標籤資料)。WMS 119
可將指示掃描或包裹識別符的讀取的每一事件以及包裹識別符、時間、日期、位置、使用者識別符或其他資訊儲存於對應資料庫(未描繪)中,且可將此資訊提供至其他系統(例如,運送及訂單追蹤系統111)。
在一些實施例中,WMS 119可儲存使一或多個裝置(例如,裝置107A至裝置107C或裝置119A至裝置119C)與一或多個使用者(所述一或多個使用者與系統100相關聯)相關聯的資訊。舉例而言,在一些情形下,使用者(諸如兼職雇員或全職雇員)可與行動裝置相關聯,此是由於使用者擁有行動裝置(例如,行動裝置為智慧型電話)。在其他情形下,使用者可與行動裝置相關聯,此是由於使用者暫時保管行動裝置(例如,使用者在一天開始時拿到行動裝置,將在一天期間使用所述行動裝置,且將在一天結束時退還所述行動裝置)。
在一些實施例中,WMS 119可維護與系統100相關聯的每一使用者的工作日志。舉例而言,WMS 119可儲存與每一雇員相關聯的資訊,包含任何指定的過程(例如,自卡車卸載、自揀貨區揀取物件、合流牆(rebin wall)工作、包裝物件)、使用者識別符、位置(例如,履行中心200中的樓層或區)、藉由雇員經由系統移動的單位數目(例如,所揀取物件的數目、所包裝物件的數目)、與裝置(例如,裝置119A至裝置119C)相關聯的識別符,或類似者。在一些實施例中,WMS 119可自計時系統接收登記及登出資訊,所述計時系統諸如在裝置119A至裝置119C上操作的計時系統。
在一些實施例中,第3方履行(3rd party fulfillment;3PL)
系統121A至第3方履行系統121C表示與物流及產品的第三方提供商相關聯的電腦系統。舉例而言,儘管一些產品儲存於履行中心200中(如下文相對於圖2所論述),但其他產品可儲存於場外、可按需求生產,或可以其他方式不可供用於儲存於履行中心200中。3PL系統121A至3PL系統121C可經組態以(例如,經由FMG 115)自FO系統113接收訂單,且可直接為客戶提供產品及/或服務(例如,遞送或安裝)。在一些實施例中,3PL系統121A至3PL系統121C中的一或多者可為系統100的部分,而在其他實施例中,3PL系統121A至3PL系統121C中的一或多者可在系統100外部(例如,由第三方提供商擁有或操作)。
在一些實施例中,履行中心Auth系統(FC Auth)123可實行為具有各種功能的電腦系統。舉例而言,在一些實施例中,FC Auth 123可充當系統100中的一或多個其他系統的單一簽入(single-sign on;SSO)服務。舉例而言,FC Auth 123可使得使用者能夠經由內部前端系統105登入、判定使用者具有存取運送及訂單追蹤系統111處的資源的類似特權,且使得使用者能夠在不需要第二登入過程的情況下取得彼等特權。在其他實施例中,FC Auth 123可使得使用者(例如,雇員)能夠使自身與特定任務相關聯。舉例而言,一些雇員可能不具有電子裝置(諸如裝置119A至裝置119C),且實際上可能在一天的過程期間在履行中心200內自任務至任務以及自區至區移動。FC Auth 123可經組態以使得彼等雇員能夠在一天的不同時間指示其正進行何任務以及其位於何區。
在一些實施例中,勞動管理系統(LMS)125可實行為儲
存雇員(包含全職雇員及兼職雇員)的出勤及超時資訊的電腦系統。舉例而言,LMS 125可自FC Auth 123、WMS 119、裝置119A至裝置119C、運輸系統107及/或裝置107A至裝置107C接收資訊。
圖1A中所描繪的特定組態僅為實例。舉例而言,儘管圖1A描繪連接至FO系統113的FC Auth系統123,但並非所有實施例均要求此特定組態。實際上,在一些實施例中,系統100中的系統可經由一或多個公用或私用網路彼此連接,所述網路包含網際網路、企業內部網路、廣域網路(Wide-Area Network;WAN)、都會區域網路(Metropolitan-Area Network;MAN)、順應IEEE 802.11a/b/g/n標準的無線網路、租用線,或類似者。在一些實施例中,系統100中的系統中的一或多者可實行為在資料中心、伺服器群或類似者處實行的一或多個虛擬伺服器。
圖2描繪履行中心200。履行中心200為儲存用於在訂購時運送至客戶的物件的實體位置的實例。可將履行中心(FC)200劃分成多個區,所述區中的每一者描繪於圖2中。在一些實施例中,可認為此等「區」為接收物件、儲存物件、取回物件以及運送物件的過程的不同階段之間的虛擬劃分。因此,儘管在圖2中描繪「區」,但其他區劃分為可能的,且在一些實施例中可省略、複製或修改圖2中的區。
入站區203表示FC 200的自希望使用來自圖1A的系統100出售產品的賣方接收到物件的區域。舉例而言,賣方可使用卡車201來遞送物件202A及物件202B。物件202A可表示足夠大以佔據其自身運送托板的單一物件,而物件202B可表示在同一托
板上堆疊在一起以節省空間的物件集合。
工作者將在入站區203中接收物件,且可使用電腦系統(未描繪)來視情況檢查物件的損壞及正確性。舉例而言,工作者可使用電腦系統來比較物件202A及物件202B的數量與物件的所訂購數量。若數量不匹配,則工作者可拒絕物件202A或物件202B中的一或多者。若數量的確匹配,則工作者可(使用例如台車、手推平車、叉車或手動地)將彼等物件移動至緩衝區205。緩衝區205可為當前(例如由於揀貨區中存在足夠高數量的物件以滿足預報需求而)無需處於揀貨區中的所述物件的暫時儲存區域。在一些實施例中,叉車206操作以圍繞緩衝區205及在入站區203與卸貨區207之間移動物件。若(例如,由於預報需求而)需要揀貨區中的物件202A或物件202B,則叉車可將物件202A或物件202B移動至卸貨區207。
卸貨區207可為FC 200的在將物件移動至揀貨區209之前儲存所述物件的區域。指定給揀貨任務的工作者(「揀貨員」)可靠近揀貨區中的物件202A及物件202B,使用行動裝置(例如,裝置119B)來掃描揀貨區的條碼,且掃描與物件202A及物件202B相關聯的條碼。揀貨員可接著(例如,藉由將物件置放於推車上或攜帶所述物件)將所述物件取至揀貨區209。
揀貨區209可為FC 200的將物件208儲存於儲存單元210上的區域。在一些實施例中,儲存單元210可包括實體擱架、書架、盒、手提包、冰箱、冷凍機、冷儲存區或類似者中的一或多者。在一些實施例中,揀貨區209可組織成多個樓層。在一些實施例中,工作者或機器可以多種方式將物件移動至揀貨區209中,
包含例如叉車、電梯、傳送帶、推車、手推平車、台車、自動化機器人或裝置,或手動地移動。舉例而言,揀貨員可在卸貨區207中將物件202A及物件202B置放於手推平車或推車上,且將物件202A及物件202B步移至揀貨區209。
揀貨員可接收將物件置放(或「堆裝」)於揀貨區209中的特定點(諸如儲存單元210上的特定空間)的指令。舉例而言,揀貨員可使用行動裝置(例如,裝置119B)來掃描物件202A。裝置可例如使用指示走道、貨架以及位置的系統來指示揀貨員應將物件202A堆裝於何處。裝置可接著提示揀貨員在將物件202A堆裝於所述位置之前掃描所述位置處的條碼。裝置可(例如,經由無線網路)將資料發送至諸如圖1A中的WMS 119的電腦系統,從而指示已由使用裝置119B的使用者將物件202A堆裝於所述位置處。
一旦使用者下訂單,揀貨員即可在裝置119B上接收自儲存單元210取回一或多個物件208的指令。揀貨員可取回物件208、掃描物件208上的條碼,且將所述物件208置放於運輸機構214上。儘管將運輸機構214表示為滑動件,但在一些實施例中,運輸機構可實行為傳送帶、電梯、推車、叉車、手推平車、台車或類似者中的一或多者。物件208可接著抵達包裝區211。
包裝區211可為FC 200的自揀貨區209接收到物件且將所述物件包裝至盒或包中以用於最終運送至客戶的區域。在包裝區211中,指定給接收物件的工作者(「合流工作者」)將自揀貨區209接收物件208且判定所述物件208對應於哪一訂單。舉例而言,合流工作者可使用諸如電腦119C的裝置來掃描物件208上的
條碼。電腦119C可在視覺上指示物件208與哪一訂單相關聯。此可包含例如對應於訂單的牆216上的空間或「單元格」。一旦訂單完成(例如,由於單元格含有所述訂單的所有物件),合流工作者即可指示包裝工作者(或「包裝員」)訂單完成。包裝員可自單元格取回物件且將所述物件置放於盒或包中以用於運送。包裝員可接著例如經由叉車、推車、台車、手推平車、傳送帶、手動地或以其他方式將盒或包發送至樞紐區(hub zone)213。
樞紐區213可為FC 200的自包裝區211接收所有盒或包(「包裹」)的區域。樞紐區213中的工作者及/或機器可取回包裹218且判定每一包裹預期去至遞送區域的哪一部分,且將包裹投送至適當的營地區(camp zone)215。舉例而言,若遞送區域具有兩個更小子區域,則包裹將去至兩個營地區215中的一者。在一些實施例中,工作者或機器可(例如,使用裝置119A至裝置119C中的一者)掃描包裹以判定其最終目的地。將包裹投送至營地區215可包括例如(例如,基於郵遞碼)判定包裹去往的地理區域的一部分,以及判定與地理區域的所述部分相關聯的營地區215。
在一些實施例中,營地區215可包括一或多個建築物、一或多個實體空間或一或多個區域,其中自樞紐區213接收包裹以用於分選至路線及/或子路線中。在一些實施例中,營地區215與FC 200實體地分開,而在其他實施例中,營地區215可形成FC 200的一部分。
營地區215中的工作者及/或機器可例如基於下述者來判定包裹220應與哪一路線及/或子路線相關聯:目的地與現有路線及/或子路線的比較、對每一路線及/或子路線的工作負荷的計算、
時刻、運送方法、運送包裹220的成本、與包裹220中的物件相關聯的PDD,或類似者。在一些實施例中,工作者或機器可(例如,使用裝置119A至裝置119C中的一者)掃描包裹以判定其最終目的地。一旦將包裹220指定給特定路線及/或子路線,工作者及/或機器即可移動待運送的包裹220。在例示性圖2中,營地區215包含卡車222、汽車226以及遞送工作者224A及遞送工作者224B。在一些實施例中,卡車222可由遞送工作者224A駕駛,其中遞送工作者224A為遞送FC 200的包裹的全職雇員,且卡車222由擁有、租用或操作FC 200的同一公司擁有、租用或操作。在一些實施例中,汽車226可由遞送工作者224B駕駛,其中遞送工作者224B為在視需要基礎上(例如,季節性地)遞送的「靈活」或臨時工作者。汽車226可由遞送工作者224B擁有、租用或操作。
根據本揭露內容的一些實施例,系統100或其子系統中的一或多者(例如,外部前端系統103)可實行於多個伺服器裝置或雲端計算環境中的虛擬伺服器中。此等伺服器裝置或虛擬伺服器可在下文統稱為遠端伺服器。遠端伺服器可包含類似於上文所描述的各種其他伺服器的組件及功能的組件及功能。因此,取決於系統100的購物者的數目,在操作中活動的遠端伺服器的數目可取決於操作需要而按比例擴大或縮小。藉助於實例,圖3描繪包含多個遠端伺服器的系統的示意圖,包含中央資料庫(database;DB)302、區域快取304a至區域快取304d、遠端伺服器306a至遠端伺服器306d以及客戶308。
中央DB 302可表示系統100的一或多個集中式資料庫。集中式資料庫可指含有為整個系統所共用且不特定地與單一遠端
伺服器中的任一者相關聯的資料的記憶體儲存器。中央DB 302可含有表示系統100上的用於出售的產品以及可與此等產品相關聯的任何資訊的資料。中央DB 302可包含經組態以儲存資料及/或指令的一或多個邏輯上及/或實體上分離的資料庫。在一個例示性實施例中,中央DB 302可使用非暫時性電腦可讀儲存媒體來實行。在另一例示性實施例中,中央DB 302可維持於網路附接儲存裝置中、儲存區域網路或其組合中等。中央DB 302可將資料儲存於儲存裝置上,所述儲存裝置可包含例如硬碟驅動機、RAID陣列、固態驅動機、反或(NOR)或反及(NAND)快閃記憶體裝置及/或唯讀記憶體(Read Only Memory;ROM)裝置。此外,中央DB 302可使用眾多類型的資料庫軟體及程式設計語言(例如,SQL、MySQL、IBM DB2®、微軟Access®、PERL、C/C++、爪哇(Java)®等)來維持及查詢。
區域快取304a至區域快取304d可表示分別特定地與諸如遠端伺服器306a至遠端伺服器306d的遠端伺服器相關聯的一或多個區域快取。區域快取可指電腦記憶體儲存器,可在一時段內保存資料。區域快取304a至區域快取304d可為硬體快取,諸如CPU快取、GPU快取及/或其他資料儲存電路系統。區域快取304a至區域快取304d亦可為軟體快取,諸如磁碟快取、頁快取、網頁快取及/或用於記憶體及資料管理的軟體程式。區域快取304a至區域快取304d可含有表示系統100上的用於出售的產品以及可與此等產品相關聯的任何資訊的資料。在一些實施例中,含於區域快取304a至區域快取304d中的資料可為含於中央DB 302中的資料中的一些或全部的複本。
遠端伺服器306a至遠端伺服器306d可表示實行系統100或其子系統中的一或多者(例如,外部前端系統103)的伺服器裝置或虛擬伺服器。每一遠端伺服器可具有資源限制,且因此可僅能夠支援預定數目個客戶308的操作。舉例而言,若每一遠端伺服器在任何給定時間僅可支援至多250個客戶,且存在1000個客戶,則例如遠端伺服器306a可處置客戶1至客戶250,遠端伺服器306b可處置客戶251至客戶500等等。在一些實施例中,在操作中的遠端伺服器的數目可取決於使用系統的客戶的數目而增加或減少。每一遠端伺服器可自對應區域快取存取資料。舉例而言,遠端伺服器306a可存取儲存於區域快取304a中的資料;遠端伺服器306b可存取儲存於區域快取304b中的資料;等等。下文將描述此組態的優勢。
在無對應區域快取的情況下,每一遠端伺服器306a至遠端伺服器306d必須自集中式資料庫302存取資料。取決於客戶的數目及每一客戶存取資料的頻繁程度,遠端伺服器306a至遠端伺服器306d與集中式資料庫302之間的資料訊務的量可能過高,從而要求額外基礎架構(例如,額外伺服器),或導致通信延遲。藉由在區域快取304a至區域快取304d上複製集中式資料庫302的一些或所有資料,每一遠端伺服器306a至遠端伺服器306d可區域地存取客戶所需的資料中的一些,從而消除伺服器306a至伺服器306d與中央資料庫302之間的大量網路訊務。因此,可能有利的是在區域快取304a至區域快取304d上包含儘可能多的資料以消除每一遠端伺服器306a至遠端伺服器306d與集中式資料庫302之間的不必要通信。在一些實施例中,某一類型的資料可較佳地儲
存於區域快取304a至區域快取304d中。舉例而言,與風行或以其他方式產生高客戶關注的產品相關的資料可較佳地儲存於區域快取304a至區域快取304d中,此是由於對此等資料的區域存取可能在減少遠端伺服器306a至遠端伺服器306d與集中式資料庫302之間的網路訊務方面具有最大影響。
然而,在系統100上列出的用於出售的產品可能不時地變化。舉例而言,可將一或多個新產品添加至系統100,及/或可移除一或多個現有產品。此外,關於產品的資訊(諸如價格、促銷狀態、數量以及其他此類資訊)可隨時間改變。若客戶存取過時的資料,則客戶體驗可能受損。因此,儲存於區域快取中的資料必須與最新資料以及與遠端伺服器306a至遠端伺服器306d的區域快取304a至區域快取304d中的其他資料同步。
藉助於實例,圖4描繪展示與所揭露實施例一致的用於基於與一或多個產品相關聯的內容更新來更新區域快取304a至區域快取304d的例示性過程400的示意圖。
在一個例示性實施例中,伺服器402可提供內容更新。內容更新可指對儲存於區域快取304a至區域快取304d中的任一者中的資料的添加、刪除、修改或任何其他改變。伺服器402可表示能夠將資料傳輸至其他電腦系統的任何伺服器裝置或虛擬伺服器。在一些例示性實施例中,伺服器402可實施系統100的一或多個子系統的操作,所述子系統諸如內部前端系統105、賣方入口網站109、供應鏈管理系統117及/或第3方履行121A至第三方履行121C。伺服器402可將內容更新提供至遠端伺服器306a至遠端伺服器306d中的一或多者。在一些實施例中,首先自伺服器402
接收內容更新的遠端伺服器可稱為第一遠端伺服器(例如,306a)。
在接收內容更新之後,第一遠端伺服器306a可更新其對應區域快取304a。第一遠端伺服器亦可繼而將內容更新提供至中央DB 302,使得可更新中央DB 302中的對應資料項。第一遠端伺服器306a可接著將無效命令提供至訊息伺服器404以告知訊息伺服器404區域快取304a至區域快取304d需要與最新資料同步。無效命令可包含使區域快取304a至區域快取304d同步的必要資料。舉例而言,無效命令可為電腦邏輯、軟體、程式碼或用於引起電腦化資料庫中的一或多個操作的其他指令。藉助於圖4中的實例,遠端伺服器306a可為第一遠端伺服器,且在其自伺服器402接收內容更新之後,其可將更新提供至中央DB 302,且可將無效命令產生至訊息伺服器404。
訊息伺服器404可表示用於將無效命令傳播至所有遠端伺服器及其對應區域快取的通信報系統。在一些實施例中,訊息伺服器404可為支援遠端伺服器306a至遠端伺服器306d的雲端或虛擬系統基礎架構的部分。舉例而言,伺服器306a至伺服器306d可為在雲端計算的系統中操作的虛擬伺服器,且訊息伺服器404可為能夠管理雲端計算的系統內的資料通信的另一虛擬伺服器、應用程式或其他軟體模組。訊息伺服器404的實例可為諸如卡夫卡(Kafka)的串流訊息平台。在訊息伺服器404接收無效命令之後,訊息伺服器404可將更新訊息發佈至所有遠端伺服器306a至遠端伺服器306d。串流處理可指允許某一形式的並行處理的電腦程式設計或架構,此類應用程式可使用多個計算單元(或伺服器)而無需明確地管理彼等單元當中的分配、同步或通信。
在一些實施例中,更新訊息為由訊息伺服器404基於無效命令來產生的分區。如本文中所使用,分區可包含更新訊息的子組件,所述子組件以並行方式傳播出訊息伺服器404。在遠端伺服器306a至遠端伺服器306d中的每一者接收更新訊息之後,遠端伺服器306a至遠端伺服器306d中的每一者可分別更新區域快取304a至區域快取304d,因此確保所有區域快取304a至區域快取304d可同步。
藉助於實例,圖5描繪與所揭露實施例一致的去至多個遠端伺服器306a至遠端伺服器306d的例示性分區傳播的示意圖。資料502可表示由訊息伺服器404自第一遠端伺服器(例如,306a)接收到的例示性無效命令。無效命令可含有用於使區域快取同步的資料或指令。在所描繪的實例中,資料502可含有資料或指令「I-1」、「I-2」、「I-3」等。經考慮,資料502可包含任何數目個資料或指令片段。訊息伺服器404可基於資料502來產生分區504a及分區504b。因此,例如,如圖5中所繪示,分區504a可包含更新訊息502的子組件I-1、子組件I-2以及子組件I-3。同樣,分區504b可包含更新訊息502的子組件I-1、子組件I-2以及子組件I-3。儘管圖5中僅示出兩個分區504a及分區504b,經考慮,訊息伺服器404可產生任何數目個分區504a、分區504b......分區504n。在一些例示性實施例中,分區504a、分區504b可彼此相同。在圖5的實例中,分區504a與分區504b相同,所述兩個分區可為資料502的複本。
在一些例示性實施例中,訊息伺服器404可將每一分區504a、分區504b等發佈至每一遠端伺服器306a至遠端伺服器
306d。舉例而言,即使分區504a與分區504b可相同,但訊息伺服器404仍可將兩個分區傳輸至每一遠端伺服器306a至遠端伺服器306d。在一些例示性實施例中,訊息伺服器404可將所有分區傳輸至每一遠端伺服器306a至遠端伺服器306d,以確保當在同步過程期間初始化新遠端伺服器306a、新遠端伺服器306b、新遠端伺服器306c或新遠端伺服器306d時,新遠端伺服器306a、新遠端伺服器306b、新遠端伺服器306c或新遠端伺服器306d的區域快取將同步。
圖6描繪與所揭露實施例一致的用於使區域快取304a至區域快取304d同步的例示性過程600的流程圖。過程600描述圖3、圖4以及圖5中所描繪的不同元件之間的各種交互。
過程600的步驟602可包含接收內容更新。如先前所論述,內容更新可為對儲存於多個遠端伺服器306a至遠端伺服器306d中的每一者的區域快取304a至區域快取304d中的資料項的更新。資料項可表示例如與用於出售的產品相關的資訊。在一些例示性實施例中,內容更新可為自遠端伺服器306a至遠端伺服器306d的區域快取304a至區域快取304d移除對應於用於出售的產品的資料項的命令。此可例如在產品已售罄或自促銷清單移除時完成。促銷清單可包含風行或旺盛出售的產品,且因此可預期產生高訊務。因此,在一些例示性實施例中,可對可能不再為促銷清單的部分的產品解除優先排序,以免儲存於區域快取304a至區域快取304d中。可例如由圖4中所描繪的伺服器402接收到更新後的內容。內容更新可自外部系統傳輸至伺服器402,或由使用伺服器402的企業工作人員產生。
過程600的步驟604可包含將內容更新傳輸至多個遠端伺服器306a至遠端伺服器306d中的第一遠端伺服器(例如,306a)以更新第一遠端伺服器306a的區域快取(例如,304a)中的對應資料項。舉例而言,如圖4中所描繪,伺服器402可將內容更新傳輸至遠端伺服器306a,所述遠端伺服器306a繼而可更新儲存於區域快取304a中的對應資料。在一些實施例中,第一遠端伺服器306a為可接收內容更新的遠端伺服器306a至遠端伺服器306d中的第一者。舉例而言,遠端伺服器306a可與遠端伺服器306b至遠端伺服器306d實質上相同。藉助於首先接收內容更新,遠端伺服器306a可為第一遠端伺服器的實例。
過程600可視情況包含將內容更新傳輸至中央資料庫302以引起儲存於中央資料庫302中的資料項的更新的步驟606。在一些例示性實施例中,第一遠端伺服器306a可將內容更新或一些其他指令或命令傳輸至集中式資料庫302以確保集中式資料庫302接收最新資訊。舉例而言,如圖4中所描繪,伺服器306a可更新具有最新資訊的中央DB 302。在一些實施例中,集中式資料庫302可由其他構件更新。舉例而言,伺服器402可直接提供對中央DB 302的更新。
過程600的步驟608可包含將無效命令產生至訊息伺服器404。在一些實施例中,無效命令可經組態以指示第一遠端伺服器306a的區域快取304a中的對應資料項的改變。舉例而言,無效命令可為電腦邏輯、軟體、程式碼或用於引起電腦化資料庫中的一或多個操作的其他指令。
過程600的步驟610可包含將無效命令自第一遠端伺服
器306a傳輸至訊息伺服器404。
過程600的步驟612可包含由訊息伺服器404基於接收到的無效命令502產生一或多個分區504(例如,504a、504b等)。在一些例示性實施例中,分區表示在計算裝置之間傳達的資料串流的部分或子組件。在其他例示性實施例中,訊息伺服器404可產生彼此相同的分區。在一些實施例中,分區504a、分區504b中的每一者包含無效命令的複本。舉例而言,如圖5中所描繪,訊息伺服器404可產生在內容方面彼此相同的分區504a及分區504b。504a或504b的內容為與無效命令502相同的內容。
過程600的步驟614可包含將多個分區(例如,504a、504b等)自訊息伺服器404傳輸至多個遠端伺服器306a至遠端伺服器306d中的每一者。在一些實施例中,多個分區504a、分區504b等可使得遠端伺服器306a至遠端伺服器306d更新其各別區域快取304a至區域快取304d。藉助於實例,如圖5中所描繪,訊息伺服器404將所有分區(分區504a及分區504b兩者)傳輸至遠端伺服器306a至遠端伺服器306d。當遠端伺服器306a至遠端伺服器306d中的每一者接收504a或504b的複本時,遠端伺服器306a至遠端伺服器306d可更新其對應區域快取304a至區域快取304d以確保同步。
如先前所論述,在一些例示性實施例中,系統300可進行對遠端伺服器306a至遠端伺服器306d的網路訊務的主動監視。舉例而言,系統300可監視可使用遠端伺服器306a至遠端伺服器306d中的任一者的客戶308的數目、存取區域快取304a至區域快取304d的頻率以及用於維持系統300的操作的其他相關度量。系
統300可基於監視來判定一或多個過載遠端伺服器306a至過載遠端伺服器306d,過載遠端伺服器306a至過載遠端伺服器306d可包含具有大於臨限值的網路訊務的遠端伺服器306a至遠端伺服器306d中的一或多者。舉例而言,當使用遠端伺服器306d的客戶308的數目超出能力(例如,超出使用者的最大數目)時,或當所有遠端伺服器306a至遠端伺服器306d可能無法滿足操作需求(例如,遠端伺服器306a至遠端伺服器306d可能不能夠處置網路訊務的容體)時,或當遠端伺服器306a至遠端伺服器306d中的一或多者失效時,系統300可採取額外步驟以補救過載。
舉例而言,為了補救上述情形,系統300可初始化具有區域快取的新遠端伺服器306m,新遠端伺服器306m為遠端伺服器306a至遠端伺服器306d附加的。系統300可接著將網路訊務的部分自過載遠端伺服器306a至過載遠端伺服器306d中的至少一者引導至新遠端伺服器306m。在一些實施例中,新遠端伺服器306m的區域快取304m可經組態以儲存與遠端伺服器306a至遠端伺服器306d的區域快取304a至區域快取304d相同的資料。藉助於實例,在遠端伺服器306a至遠端伺服器306d中的一或多者無法滿足需求的情形下,可初始化額外新遠端伺服器306m,且此新遠端伺服器(或新遠端306m)亦可包含儲存與區域快取304a至區域快取304d相同的資料的區域快取304m。如本文中所使用,初始化可指創建新遠端伺服器或將其連接至現有遠端伺服器的過程或操作步驟。初始化可包含設置用於與現有遠端伺服器及區域快取一起操作的新遠端306m及用於與現有遠端伺服器及區域快取一起操作的區域快取304m。
在一些例示性實施例中,新遠端伺服器306m的初始化可在系統300嘗試基於內容更新使區域快取304a至區域快取304d同步時發生。為確保新遠端306m的新初始化區域快取304m亦同步,訊息伺服器404可確保多個分區504a、分區504b等經組態以確保新遠端伺服器306m的區域快取304m經更新,而不管新遠端伺服器306m的初始化的時間為何。舉例而言,由於每一分區504a、分區504b等能夠使區域快取304a至區域快取304d同步,且多個分區504a、分區504b等可由訊息伺服器404發送,故並非所有分區504a、分區504b等可為遠端伺服器306a至遠端伺服器306d所需以使其區域快取304a至區域快取304d同步。前已述及,更新訊息可劃分成相同的分區504a及分區504b。由於訊息伺服器404在並行過程中傳播分區,故每一分區經設計以到達每一遠端伺服器。在本實施例中,當504a及504b兩者單獨經程式化以使區域快取同步時,即使新遠端伺服器306m錯過分區504a或分區504b中的一者,其區域快取304m亦可經同步,只要接收到至少一個分區即可。舉例而言,如圖5中所描繪,即使新遠端伺服器306m在其初始化期間錯過分區504a,其仍可接收分區504b且仍將作為結果經同步。
儘管已參考本揭露內容的特定實施例繪示及描述本揭露內容,但應理解,可在不修改的情況下在其他環境中實踐本揭露內容。已出於示出的目的呈現前述描述。前述描述並不詳盡且不限於所揭露的精確形式或實施例。修改及調適對所屬技術領域中具有通常知識者將自本說明書的考量及所揭露實施例的實踐顯而易見。另外,儘管將所揭露實施例的態樣描述為儲存於記憶體中,但
所屬技術領域中具有通常知識者應瞭解,此等態樣亦可儲存於其他類型的電腦可讀媒體上,諸如次級儲存裝置,例如硬碟或CD ROM,或其他形式的RAM或ROM、USB媒體、DVD、藍光,或其他光碟機媒體。
基於書面描述及所揭露方法的電腦程式在有經驗開發者的技能內。各種程式或程式模組可使用所屬技術領域中具有通常知識者已知的技術中的任一者來創建或可結合現有軟體來設計。舉例而言,程式區段或程式模組可以或藉助於.Net框架(.Net Framework)、.Net緊密框架(.Net Compact Framework)(及相關語言,諸如視覺培基(Visual Basic)、C等)、爪哇、C++、目標-C(Objective-C)、HTML、HTML/AJAX組合、XML或包含爪哇小程式的HTML來設計。
此外,儘管本文中已描述示出性實施例,但所屬技術領域中具有通常知識者將基於本揭露內容瞭解具有等效元件、修改、省略、(例如,各種實施例中的態樣的)組合、調適及/或更改的任何及所有實施例的範圍。申請專利範圍中的限制應基於申請專利範圍中所採用的語言來廣泛地解釋,且不限於本說明書中所描述或在本申請案的審查期間的實例。實例應視為非排他性的。另外,所揭露方法的步驟可以包含藉由對步驟重新排序及/或插入或刪除步驟的任何方式修改。因此,希望僅將本說明書及實例視為示出性的,其中藉由以下申請專利範圍及其等效物的完整範圍指示真實範圍及精神。
302:中央資料庫/集中式資料庫
304a、304b、304c、304d、304m:區域快取
306a、306b、306c、306d、306m:遠端伺服器
400:過程
402:伺服器
404:訊息伺服器
Claims (18)
- 一種用於使區域快取同步的電腦實行系統,所述系統包括:一或多個處理器;以及至少一個記憶體儲存裝置,儲存指令,所述指令在由所述一或多個處理器執行時使得所述一或多個處理器進行包括下述者的操作:接收內容更新,所述內容更新包含對儲存於多個遠端伺服器中的每一者的區域快取中的資料項的更新;將所述內容更新傳輸至所述多個遠端伺服器中的第一遠端伺服器以更新所述第一遠端伺服器的所述區域快取中的對應資料項;產生無效命令,所述無效命令經組態以指示所述第一遠端伺服器的所述區域快取中的所述對應資料項的改變;將所述無效命令自所述第一遠端伺服器傳輸至訊息伺服器;由所述訊息伺服器基於接收到的所述無效命令產生多個分區,所述多個分區包括第一分區以及第二分區,所述第一分區以及所述第二分區分開且內容相同;將所述多個分區自所述訊息伺服器傳輸至所述多個遠端伺服器中的每一者,其中所述多個分區使得所述多個遠端伺服器中的每一者更新各別區域快取。
- 如請求項1所述的電腦實行系統,所述操作更包括將所述內容更新傳輸至中央資料庫以引起儲存於所述中央資料庫中的資料項的更新。
- 如請求項2所述的電腦實行系統,其中儲存於所述多個遠端伺服器中的每一者的所述區域快取中的所述資料項及儲存於所述中央資料庫中的所述資料項與用於出售的產品相關聯。
- 如請求項3所述的電腦實行系統,其中所述內容更新為自所述多個遠端伺服器中的每一者的所述區域快取移除對應於用於出售的所述產品的所述資料項的命令。
- 如請求項1所述的電腦實行系統,所述操作更包括:監視所述多個遠端伺服器的網路訊務;基於所述監視判定至少一個過載遠端伺服器,所述過載遠端伺服器包含所述多個遠端伺服器中的具有大於臨限值的網路訊務的一或多者;使具有區域快取的新遠端伺服器初始化,所述新遠端伺服器為所述多個遠端伺服器所附加;以及將所述網路訊務的部分自所述至少一個過載遠端伺服器引導至所述新遠端伺服器,其中所述新遠端伺服器的所述區域快取經組態以儲存與所述多個遠端伺服器中的每一者的所述區域快取相同的資料。
- 如請求項5所述的電腦實行系統,其中所述多個分區經組態以確保更新所述新遠端伺服器的所述區域快取,而不管所述新遠端伺服器的初始化的時間為何。
- 如請求項1所述的電腦實行系統,其中所述多個分區中的每一者包含所述無效命令的複本。
- 如請求項1所述的電腦實行系統,其中所述第一遠端伺服器為所述多個遠端伺服器中的接收所述內容更新的第一 者。
- 如請求項1所述的電腦實行系統,其中所述訊息伺服器為串流處理伺服器。
- 一種用於使區域快取同步的電腦實行方法,包括:接收內容更新,所述內容更新包含對儲存於多個遠端伺服器中的每一者的區域快取中的資料項的更新;將所述內容更新傳輸至所述多個遠端伺服器中的第一遠端伺服器以更新所述第一遠端伺服器的所述區域快取中的對應資料項;產生無效命令,所述無效命令經組態以指示所述第一遠端伺服器的所述區域快取中的所述對應資料項的改變;將所述無效命令自所述第一遠端伺服器傳輸至訊息伺服器;由所述訊息伺服器基於接收到的所述無效命令產生多個分區,所述多個分區包括第一分區以及第二分區,所述第一分區以及所述第二分區分開且內容相同;以及將所述多個分區自所述訊息伺服器傳輸至所述多個遠端伺服器中的每一者,其中所述多個分區使得所述多個遠端伺服器中的每一者更新各別區域快取。
- 如請求項10所述的電腦實行方法,所述方法更包括:將所述內容更新傳輸至中央資料庫以引起儲存於所述中央資料庫中的資料項的更新。
- 如請求項11所述的電腦實行方法,其中儲存於所述多個遠端伺服器中的每一者的所述區域快取中的所述資料項及儲存於所述中央資料庫中的所述資料項與用於出售的產品相關聯。
- 如請求項12所述的電腦實行方法,其中所述內容更新為自所述多個遠端伺服器中的每一者的所述區域快取移除對應於用於出售的所述產品的所述資料項的命令。
- 如請求項10所述的電腦實行方法,所述方法更包括:監視所述多個遠端伺服器的網路訊務;基於所述監視判定至少一個過載遠端伺服器,所述過載遠端伺服器包含所述多個遠端伺服器中的具有大於臨限值的網路訊務的一或多者;使具有區域快取的新遠端伺服器初始化,所述新遠端伺服器為所述多個遠端伺服器所附加;以及將所述網路訊務的部分自所述至少一個過載遠端伺服器引導至所述新遠端伺服器,其中所述新遠端伺服器的所述區域快取經組態以儲存與所述多個遠端伺服器中的每一者的所述區域快取相同的資料。
- 如請求項14所述的電腦實行方法,其中所述多個分區經組態以確保更新所述新遠端伺服器的所述區域快取,而不管所述新遠端伺服器的初始化的時間為何。
- 如請求項10所述的電腦實行方法,其中所述多個分區中的每一者包含所述無效命令的複本。
- 如請求項10所述的電腦實行方法,其中所述第一遠端伺服器為所述多個遠端伺服器中的接收所述內容更新的第一者。
- 一種用於使區域快取同步的電腦實行系統,包括:一或多個處理器;以及 至少一個記憶體儲存裝置,儲存指令,所述指令在由所述一或多個處理器執行時進行包括下述者的操作:接收內容更新,所述內容更新為移除儲存於多個遠端伺服器的區域快取中的資料項的命令;將所述內容更新傳輸至所述多個遠端伺服器中的第一遠端伺服器以移除所述第一遠端伺服器的所述區域快取中的對應資料項;向訊息伺服器產生無效命令,所述無效命令經組態以移除所述第一遠端伺服器的所述區域快取中的所述對應資料項;將所述無效命令自所述第一遠端伺服器傳輸至所述訊息伺服器,所述訊息伺服器為串流處理伺服器;由所述訊息伺服器產生多個分區,所述多個分區中的每一者包含所述無效命令的複本,所述多個分區包括第一分區以及第二分區,所述第一分區以及所述第二分區分開且內容相同;以及將所述多個分區自所述訊息伺服器傳輸至所述多個遠端伺服器,其中所述多個分區使得所述多個遠端伺服器移除其各別區域快取中的對應資料項。
Applications Claiming Priority (2)
Application Number | Priority Date | Filing Date | Title |
---|---|---|---|
US17/120,884 US11151032B1 (en) | 2020-12-14 | 2020-12-14 | System and method for local cache synchronization |
US17/120,884 | 2020-12-14 |
Publications (2)
Publication Number | Publication Date |
---|---|
TW202223678A TW202223678A (zh) | 2022-06-16 |
TWI804860B true TWI804860B (zh) | 2023-06-11 |
Family
ID=78083122
Family Applications (1)
Application Number | Title | Priority Date | Filing Date |
---|---|---|---|
TW110116243A TWI804860B (zh) | 2020-12-14 | 2021-05-05 | 用於使區域快取同步的電腦實行系統以及方法 |
Country Status (4)
Country | Link |
---|---|
US (2) | US11151032B1 (zh) |
KR (2) | KR102422809B1 (zh) |
TW (1) | TWI804860B (zh) |
WO (1) | WO2022129992A1 (zh) |
Families Citing this family (1)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20230128035A1 (en) * | 2021-10-21 | 2023-04-27 | EMC IP Holding Corpany, LLC | System and Method for Distributed Data Consolidation |
Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US20030088442A1 (en) * | 2001-10-23 | 2003-05-08 | Michael Martin W. | Inventory management system and method |
US6618705B1 (en) * | 2000-04-19 | 2003-09-09 | Tiejun (Ronald) Wang | Method and system for conducting business in a transnational e-commerce network |
US20030236957A1 (en) * | 2002-06-21 | 2003-12-25 | Lawrence Miller | Method and system for data element change across multiple instances of data base cache |
US20040073755A1 (en) * | 2000-08-31 | 2004-04-15 | Webb David A.J. | Broadcast invalidate scheme |
US6792436B1 (en) * | 2000-02-11 | 2004-09-14 | Persistence Software, Inc. | Method for synchronizing multiple software caches in a memory |
US20060195525A1 (en) * | 2002-04-24 | 2006-08-31 | Page David C | Distributed application server and method for implementing distributed functions |
US20100174863A1 (en) * | 2007-11-30 | 2010-07-08 | Yahoo! Inc. | System for providing scalable in-memory caching for a distributed database |
TWI620063B (zh) * | 2016-03-10 | 2018-04-01 | 美光科技公司 | 用於快取無效之裝置及方法 |
Family Cites Families (6)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6205481B1 (en) * | 1998-03-17 | 2001-03-20 | Infolibria, Inc. | Protocol for distributing fresh content among networked cache servers |
US6920532B2 (en) * | 2002-11-05 | 2005-07-19 | Newisys, Inc. | Cache coherence directory eviction mechanisms for modified copies of memory lines in multiprocessor systems |
US7788452B2 (en) * | 2004-01-20 | 2010-08-31 | International Business Machines Corporation | Method and apparatus for tracking cached addresses for maintaining cache coherency in a computer system having multiple caches |
US20100228819A1 (en) * | 2009-03-05 | 2010-09-09 | Yottaa Inc | System and method for performance acceleration, data protection, disaster recovery and on-demand scaling of computer applications |
US8352602B2 (en) | 2009-07-01 | 2013-01-08 | Juniper Networks, Inc. | Arrangements and methods for access to stored data |
WO2015081308A2 (en) * | 2013-11-26 | 2015-06-04 | Dynavisor, Inc. | Dynamic i/o virtualization |
-
2020
- 2020-12-14 US US17/120,884 patent/US11151032B1/en active Active
- 2020-12-16 KR KR1020217019001A patent/KR102422809B1/ko active
- 2020-12-16 WO PCT/IB2020/062033 patent/WO2022129992A1/en active Application Filing
- 2020-12-16 KR KR1020227024419A patent/KR20230110442A/ko not_active Application Discontinuation
-
2021
- 2021-05-05 TW TW110116243A patent/TWI804860B/zh active
- 2021-08-25 US US17/411,443 patent/US11704244B2/en active Active
Patent Citations (8)
Publication number | Priority date | Publication date | Assignee | Title |
---|---|---|---|---|
US6792436B1 (en) * | 2000-02-11 | 2004-09-14 | Persistence Software, Inc. | Method for synchronizing multiple software caches in a memory |
US6618705B1 (en) * | 2000-04-19 | 2003-09-09 | Tiejun (Ronald) Wang | Method and system for conducting business in a transnational e-commerce network |
US20040073755A1 (en) * | 2000-08-31 | 2004-04-15 | Webb David A.J. | Broadcast invalidate scheme |
US20030088442A1 (en) * | 2001-10-23 | 2003-05-08 | Michael Martin W. | Inventory management system and method |
US20060195525A1 (en) * | 2002-04-24 | 2006-08-31 | Page David C | Distributed application server and method for implementing distributed functions |
US20030236957A1 (en) * | 2002-06-21 | 2003-12-25 | Lawrence Miller | Method and system for data element change across multiple instances of data base cache |
US20100174863A1 (en) * | 2007-11-30 | 2010-07-08 | Yahoo! Inc. | System for providing scalable in-memory caching for a distributed database |
TWI620063B (zh) * | 2016-03-10 | 2018-04-01 | 美光科技公司 | 用於快取無效之裝置及方法 |
Also Published As
Publication number | Publication date |
---|---|
KR102422809B1 (ko) | 2022-07-20 |
TW202223678A (zh) | 2022-06-16 |
US11151032B1 (en) | 2021-10-19 |
KR20220088628A (ko) | 2022-06-28 |
US20220188227A1 (en) | 2022-06-16 |
KR20230110442A (ko) | 2023-07-24 |
WO2022129992A1 (en) | 2022-06-23 |
US11704244B2 (en) | 2023-07-18 |
Similar Documents
Publication | Publication Date | Title |
---|---|---|
TWI801861B (zh) | 根據產品特性決定產品價格的倉儲管理電腦實行系統以及方法 | |
TWI759825B (zh) | 用於出站預測之電腦實施系統以及電腦實施方法 | |
TWI759823B (zh) | 使用入站裝載模式於出站預測之電腦實施系統以及電腦實施方法 | |
TWI844440B (zh) | 基於系統參數有效分配訂單之電腦實施系統以及電腦實施方法 | |
TWI780560B (zh) | 用於在網站伺服器上登記產品的電腦實行系統以及方法 | |
TW202242673A (zh) | 降低資料庫查詢延遲之系統以及方法 | |
TWI743936B (zh) | 用於出站預測的電腦實施的系統以及方法 | |
TWI795913B (zh) | 用於出站預測的電腦實施的系統以及方法 | |
TWI731618B (zh) | 電腦實施系統及電腦實施方法 | |
TWI804860B (zh) | 用於使區域快取同步的電腦實行系統以及方法 | |
KR20230107504A (ko) | 분할된 데이터베이스를 위한 다중 노드의 스트림 처리프레임워크를 위한 시스템 및 방법 | |
TWI792289B (zh) | 為定製履行中心確定物件的系統以及方法 | |
TWI793488B (zh) | 用於資訊在使用者介面上的模組加載的電腦實行系統以及方法 | |
TWI793606B (zh) | 產生圖形顯示介面的方法及電腦系統 | |
TWI816112B (zh) | 用於儲存與一系列事件相關的資料的電腦實行資料庫系統以及電腦實行方法 | |
US11100166B1 (en) | Systems and methods for automatically updating guaranteed computing counters | |
TWI857275B (zh) | 用於出站預測之電腦實施方法及其電腦實施系統 | |
TW202433365A (zh) | 基於系統參數有效分配訂單之電腦實施系統以及電腦實施方法 |