精品欧美一区二区三区在线观看 _久久久久国色av免费观看性色_国产精品久久在线观看_亚洲第一综合网站_91精品又粗又猛又爽_小泽玛利亚一区二区免费_91亚洲精品国偷拍自产在线观看 _久久精品视频在线播放_美女精品久久久_欧美日韩国产成人在线

京東到家訂單派發的技術實戰

開發 開發工具 前端
本文將描述訂單派發系統從無到有的系統演進以及方案設計與關鍵要點,為大家在解決相關業務場景上提供一個案例參考。

達達-京東到家作為優秀的即時配送物流平臺,實現了多渠道的訂單配送,包括外賣平臺的餐飲訂單、新零售的生鮮訂單、知名商戶的優質訂單等。為了提升平臺的用戶粘性,我們需要兼顧商戶和騎士的各自愿景:商戶希望訂單能夠準時送達,騎士希望可以高效搶單。那么在合適的時候提升訂單定制化的曝光率,是及時送物流平臺的核心競爭力之一。

本文將描述訂單派發系統從無到有的系統演進以及方案設計與關鍵要點,為大家在解決相關業務場景上提供一個案例參考。

訂單派發架構演進

在公司發展的初期,我們的外賣訂單從商戶發單之后直接出現在搶單池中,3公里之內的騎士能夠看到訂單,并且從訂單卡片中獲取配送地址、配送時效等關鍵信息。這種暴力的顯示模式,很容易造成騎士挑選有利于自身的訂單進行配送,從而導致部分訂單超時未被配送。這樣的模式,在一定程度上導致了商戶的流失,同時也浪費了騎士的配送時間。

從上面的場景可以看出來,我們系統中缺少一個訂單核心調度者。有一種方案是選擇區域訂單的訂單調度員,由調度員根據騎士的接單情況、配送時間、訂單擠壓等實時情況來進行訂單調度。這種模式,看似可行,但是人力成本投入太高,且比較依賴個人的經驗總結。

核心問題已經出來了:個人的經驗總結會是什么呢?

  • 騎士正在配送的訂單的數量,是否已經飽和
  • 騎士的配送習慣是什么
  • 某一階段的訂單是否順路,騎士是否可以一起配送
  • 騎士到店駐留時間的預估
  •  ...

理清核心問題的答案,我們的系統派單便成為了可能?;谝陨系脑?,訂單派發模式就可以逐漸從搶單池的訂單顯示演變成系統派單。

我們將會記錄商戶發單行為、騎士配送日志及運行軌跡等信息,并且經過數據挖掘和數據分析,獲取騎士的畫像、騎士配送時間的預估、騎士到店駐留時間的預估等基礎信息;使用遺傳算法規劃出最優的配送路徑...經過上述一系列算法,我們將在騎士池中匹配出最合適的騎士,進而使用長連接(Netty)不間斷的通知到騎士。

隨著達達業務的不斷迭代,訂單配送逐漸孵化出基于大商戶的駐店模式:基于商戶維護一批固定的專屬騎士,訂單只會在運力不足的時候才會外發到搶單池中,正常情況使用派單模式通知騎士。

訂單派發模型

訂單派發可以淺顯的認為是一種信息流的推薦。在訂單進入搶單池之前,我們會根據每個城市的調度情況,先進行輪詢N次的派單。大概的表現形式如下圖:

舉例有筆訂單需要進行推送,在推送過程中,我們暫且假設一直沒有騎士接單,那么這筆訂單會每間隔N秒便會進行一次普通推薦,然后進入搶單池。

從訂單派發的流程周期上可以看出來,派發模型充斥著大量的延遲任務,只要能解決訂單在什么時候可以進行派發,那么整個系統 50% 的功能點就能迎刃而解。

我們先了解一下經典的延遲方案:

1. 數據庫輪詢

通過一個線程定時的掃描數據庫,獲取到需要派單的訂單信息

  • 優點:開發簡單,結合quartz即可以滿足分布式掃描
  • 缺點:對數據庫服務器壓力大,不利于項目后續發展

2. JDK的延遲隊列 - DelayQueue

DelayQueue是Delayed元素的一個無界阻塞隊列,只有在延遲期滿時才能從中提取元素。隊列中對象的順序按到期時間進行排序。

  • 優點:開發簡單,效率高,任務觸發時間延遲低
  • 缺點:服務器重啟后,數據會丟失,要滿足高可用場景,需要hook線程二次開發;宕機的擔憂;如果數據量暴增,也會引起OOM的情況產生

3. 時間輪 - TimingWheel

時間輪的結構原理很簡單,它是一個存儲定時任務的環形隊列,底層是由數組實現,而數組中的每個元素都可以存放一個定時任務列表,列表中的每一項都表示一個事件操作單元,當時間指針指向對應的時間格的時候,該列表中的所有任務都會被執行。 時間輪由多個時間格組成,每個時間格代表著當前實踐論的跨度,用tickMs代表;時間輪的個數是固定的,用wheelSize代表;整個時間輪的跨度用interval代表,那么指針轉了一圈的時間為:

  1. interval = tickMs * wheelSize 

如果tickMs=1ms,wheelSize=20,那么便能計算出此時的時間是以20ms為一轉動周期,時間指針(currentTime)指向wheelSize=0的數據槽,此時有5ms延遲的任務插入了wheelSize=5的時間格,隨著時間的不斷推移,指針currentTime不斷向前推進,過了5ms之后,當到達時間格5時,就需要將時間格5所對應的任務做相應的到期操作。

如果此時有個定時為180ms的任務該如何處理?很直觀的思路是直接擴充wheelSize?這樣會導致wheelSize的擴充會隨著業務的發展而不斷擴張,這樣會使時間輪占用很大的內存空間,導致效率低下,因此便衍生出了層級時間輪的數據結構。

180ms的任務會升級到第二層時間輪中,最終被插入到第二層時間輪中時間格#8所對應的TimerTaskList中。如果此時又有一個定時為600ms的任務,那么顯然第二層時間輪也無法滿足條件,所以又升級到第三層時間輪中,最終被插入到第三層時間輪中時間格#1的TimerTaskList中。注意到在到期時間在[400ms,800ms)區間的多個任務(比如446ms、455ms以及473ms的定時任務)都會被放入到第三層時間輪的時間格#1中,時間格#1對應的TimerTaskList的超時時間為400ms。

隨著時間輪的轉動,當TimerTaskList到期時,原本定時為450ms的任務還剩下50ms的時間,還不能執行這個任務的到期操作。便會有個時間輪降級的操作,會將這個剩余時間50ms的定時任務重新提交到下一層級的時間輪中,所以該任務被放到第二層時間輪到期時間為 [40ms,60ms) 的時間格中。再經歷了40ms之后,此時這個任務又被觸發到,不過還剩余10ms,還是不能立即執行到期操作。所以還要再一次的降級,此任務會被添加到第一層時間輪到期時間為[10ms,11ms)的時間格中,之后再經歷10ms后,此任務真正到期,最終執行相應的到期操作。

  • 優點:效率高,可靠性高(Netty,Kafka,Akka均有使用),便于開發
  • 缺點:數據存儲在內存中,需要自己實現持久化的方案來實現高可用

訂單派發實現方案

結合了上述的三種方案,最后決定使用redis作為數據存儲,使用timingWhell作為時間的推動者。這樣便可以將定時任務的存儲和時間推動進行解耦,依賴Redis的AOF機制,也不用過于擔心訂單數據的丟失。

kafka中為了處理成千上萬的延時任務選擇了多層時間輪的設計,我們從業務角度和開發難度上做了取舍,只選擇設計單層的時間輪便可以滿足需求。

1. 時間格和緩存的映射維護

假設當前時間currentTime為11:49:50,訂單派發時間dispatchTime為11:49:57,那么時間輪的時間格#7中會設置一個哨兵節點(作為是否有數據存儲在redis的依據 )用來表示該時間段是否會時間事件觸發,同時會將這份數據放入到緩存中(key=dispatchTime+ip), 當7秒過后,觸發了該時間段的數據,便會從redis中獲取數據,異步執行相應的業務邏輯。最后,防止由于重啟等一些操作導致數據的丟失,哨兵節點的維護也會在緩存中維護一份數據,在重啟的時候重新讀取

2. 緩存的key統一加上IP標識

由于我們的時間調度器是依附于自身系統的,通過將緩存的key統一加上IP的標識,這樣就可以保證各臺服務器消費屬于自身的數據,從而防止分布式環境下的并發問題,也可以減輕遍歷整個列表帶來的時間損耗(時間復雜度為O(N))

3. 使用異步線程處理時間格中對應的數據

使用異步線程,是考慮到如果上一個節點發生異?;蛘叱瑫r等情況,會延誤下一秒的操作,如果使用異常可以改善調度的即時性問題。

我們在設計系統的時候,系統的完善度和業務的滿足度是互相關聯影響的,單從上述的設計看,是會有些問題的,比如使用IP作為緩存的key,如果集群發生變更便會導致數據不會被消費;使用線程池異步處理也有概率導致數據不會被消費。這些不會被消費的數據會進入到搶單池中。從派單場景的需求來看,這些場景是可以被接受的,當然了,我們系統會有腳本來進行定期的篩選,將那些進入搶單池的訂單進行再次派單。

為什么不使用ScheduledThreadPoolExecutor來定時輪詢redis? 即便這樣可以完成業務上的需求,獲取定時觸發的任務,但是帶來的空查詢不但會拉高服務的CPU,redis的QPS也會被拉高,可能會導致redis的慢查詢會顯著增多。

結語

我們在完成一個功能的時候,往往需要一些可視化的數據來確定業務發展的正確性。因此我們在開發的時候,也相應的記錄了一些訂單與騎士的交互動作。從每天的報表數據可以看出來,90% 以上的訂單是通過派單發出并且被騎士認可接單。

訂單派發的模式是提升訂單曝光率有效的技術手段,我們一直結合大數據、人工智能等技術手段希望能更好的做好訂單派發,能提供更加多元化的功能,將達達打造成更加一流的配送平臺。

作者:季炳坤,任職Java工程師,負責訂單派發,訂單權限,合并訂單等相關工作。

【本文來自51CTO專欄作者張開濤的微信公眾號(開濤的博客),公眾號id: kaitao-1234567】

戳這里,看該作者更多好文

責任編輯:趙寧寧 來源: 51CTO專欄
相關推薦

2019-08-30 12:30:25

京東到家訂單查詢數據存儲

2018-12-20 06:04:02

京東到家訂單中心Elasticsear

2019-01-17 09:50:55

京東ES架構

2018-04-20 09:36:23

NettyWebSocket京東

2017-12-12 08:40:00

2019-01-02 14:55:54

MySQLES數據庫

2019-01-14 09:06:40

LBS定位系統架構

2022-02-12 20:51:23

京東程序員代碼

2021-03-18 14:34:34

達達集團京東云電商

2014-11-28 13:53:28

2019-11-01 15:50:06

MySQLES搜索引擎

2022-02-14 08:13:33

刪庫MySQL備份

2020-05-12 11:25:50

MySQLES數據庫

2015-07-17 07:47:51

京東618訂

2022-02-11 15:01:07

程序員刪庫計算機

2025-01-02 09:02:09

Go項目Token

2021-07-27 22:42:20

人工智能無人機快遞

2015-12-02 11:30:37

京東搜索京東推薦

2017-07-06 00:27:17

虛擬訂單中心京東數據

2014-08-08 15:34:49

京東大數據技術
點贊
收藏

51CTO技術棧公眾號

国产一区二区三区成人欧美日韩在线观看| 国产精品久久乐| 成人高清视频免费观看| 97欧美精品一区二区三区| 无套内谢大学处破女www小说| 亚洲性色av| 国产精品成人一区二区三区夜夜夜| 成人免费大片黄在线播放| 久久精品国产亚洲AV无码男同 | 999精品视频| 日韩欧美一区二区三区在线| 精品国产一区三区| 五月香视频在线观看| 国产91在线观看| 国产精品久久久久9999| 麻豆亚洲av熟女国产一区二| 久草成人在线| 精品日韩在线一区| 亚洲人视频在线| 中文字幕乱码中文乱码51精品| 国产精品蜜臀av| 精品国产一二| 99国产精品久久久久久久成人| 夜久久久久久| 欧美大片免费观看| 老司机精品免费视频| 亚洲妇女av| 欧美精品一区二区三区很污很色的 | 91色琪琪电影亚洲精品久久| 欧美日韩综合在线观看| 欧美韩日精品| 久久精品久久精品亚洲人| 蜜桃传媒一区二区亚洲av| 综合视频一区| 91精品国产高清一区二区三区| 能在线观看的av网站| 国产不卡123| 亚洲午夜电影网| 爱爱爱视频网站| 国产精品一级伦理| 久久毛片高清国产| 久久综合狠狠综合久久综青草| 精品国产18久久久久久| 久久福利资源站| 国产精品吹潮在线观看| 黄色在线免费观看| 亚洲精品麻豆| 午夜精品久久久99热福利| 久久精品波多野结衣| 中文乱码免费一区二区三区下载| 色老头一区二区三区在线观看| 久久久视频6r| 俺要去色综合狠狠| 最近2019年日本中文免费字幕| 国产精久久一区二区三区| 蜜桃精品wwwmitaows| 亚洲精品网站在线播放gif| 在线免费播放av| 色狼人综合干| 亚洲欧美日韩另类| 国产伦精品一区二区三区视频女| 精品一区欧美| 国产亚洲精品一区二555| jizz中文字幕| 久久亚洲国产| 欧美成人sm免费视频| 久久久91视频| 99国产精品久久久久久久| 26uuu亚洲国产精品| 天堂中文在线网| 日日夜夜精品视频免费| 国产精品揄拍一区二区| a级片在线免费看| 成人av网站免费观看| 久久免费99精品久久久久久| 国产永久免费高清在线观看视频| 国产欧美一区二区三区网站| 伊人久久大香线蕉av一区| caopo在线| 午夜精品久久久久久久99水蜜桃| 无码人妻丰满熟妇区96| 高清成人在线| 日韩视频中午一区| 亚洲中文字幕无码av| 精品一区二区三区的国产在线观看| 中文字幕欧美亚洲| 麻豆疯狂做受xxxx高潮视频| 国产精品尤物| 91精品久久久久久久久久久久久久 | 国产一区二区无遮挡| 欧美孕妇性xxxⅹ精品hd| 国产精品天美传媒| 国产精品免费看久久久无码| 精品捆绑调教一区二区三区| 欧美偷拍一区二区| wwwww在线观看| 综合伊思人在钱三区| 久久人人爽人人爽爽久久| 中日韩精品视频在线观看| 日本女优在线视频一区二区| 99在线首页视频| youjizz在线播放| 亚洲 欧美综合在线网络| 久久综合伊人77777麻豆最新章节| 国产色99精品9i| 亚洲色图欧美制服丝袜另类第一页| 中国一级片在线观看| 性欧美精品高清| 91九色极品视频| 在线中文资源天堂| 欧美日韩亚洲精品一区二区三区| www.51色.com| 国产精品视频一区二区三区四蜜臂| 美女啪啪无遮挡免费久久网站| 欧美超碰在线观看| www.一区二区| 欧美日韩激情四射| 久久久久伊人| 亚洲性生活视频在线观看| 日本少妇做爰全过程毛片| 狠狠狠色丁香婷婷综合激情| 日韩精品国内| 伊人成综合网站| 亚洲成人av片| 欧美日韩人妻精品一区二区三区| 美女网站色91| 婷婷久久青草热一区二区| 国产欧美一区二区三区精品酒店| 精品国产一区二区三区久久影院| 免费在线观看黄色小视频| 日韩精品一级中文字幕精品视频免费观看| 国内精品二区| xxxcom在线观看| 日韩精品中文字幕一区 | 99久久久久国产精品| 国产激情久久久| 精品乱码一区二区三四区视频| 午夜日韩在线观看| 中文字幕三级电影| 亚洲片区在线| 久久精品丝袜高跟鞋| 999精品网| 日韩精品免费在线视频观看| 日韩欧美一级视频| 99re6这里只有精品视频在线观看| 久久精品无码中文字幕| 超碰成人97| 欧美一级高清免费播放| 亚洲欧美综合一区二区| 欧美日韩在线视频一区二区| 亚洲色图14p| 亚洲欧美高清| 日韩亚洲不卡在线| 四虎影视国产精品| 久久国产精品久久国产精品| 国产aⅴ爽av久久久久成人| 亚洲欧美国产77777| 国产成人av免费观看| 欧美日韩91| 国产在线精品一区二区中文| 日韩大片免费观看| 亚洲无线码在线一区观看| 国产精品xxxxxx| 最好看的中文字幕久久| 国产成人av片| 亚洲永久网站| 亚洲午夜精品久久| 日韩高清在线观看一区二区| 韩国精品美女www爽爽爽视频| 天堂av资源网| 欧美日韩一区二区免费视频| 人妻一区二区视频| 久久精品99久久久| 999一区二区三区| 综合色就爱涩涩涩综合婷婷| 国产精品一区二区电影| 99在线播放| 日韩精品中文字幕有码专区| 中文字幕在线网址| 亚洲综合一二区| 91久久免费视频| 国产美女精品在线| 黄色片视频在线免费观看| 日韩在线第七页| 国产日韩欧美亚洲一区| 国产一区二区主播在线| 欧美成人剧情片在线观看| 天堂v在线观看| 欧美挠脚心视频网站| 久久久久免费看| 国产日韩精品一区二区三区在线| www.桃色.com| 欧美一级视频| 欧美日韩午夜爽爽| 国产精品亚洲片在线播放| 91沈先生作品| 经典三级一区二区| 欧美激情videos| 最新97超碰在线| 亚洲精品美女久久久| 国产理论视频在线观看| 日韩欧美在线免费观看| 欧美三根一起进三p| 国产网红主播福利一区二区| 无码人妻一区二区三区免费n鬼沢| 日本一不卡视频| 91专区在线观看| 中文一区一区三区免费在线观看| 日韩福利二区| 日韩最新在线| 国产精品白丝jk白祙| 日韩午夜视频在线| 国产成人精品网站| 爱搞国产精品| 九色精品美女在线| 黄网站在线播放| 在线播放日韩欧美| 视频在线观看你懂的| 欧美www视频| 国产乱码精品一区二区三区精东| 欧美性极品少妇| 日本特级黄色片| 五月天激情综合| 国产一级做a爰片在线看免费| 日韩一区在线免费观看| 亚洲a∨无码无在线观看| 国产午夜久久久久| 中国毛片在线观看| 久久这里只有精品首页| 国产国语老龄妇女a片| 国产成人欧美日韩在线电影| 欧美大片久久久| 久久9热精品视频| 免费看涩涩视频| 日本亚洲欧美天堂免费| 韩国日本美国免费毛片| 久久久久久9| 亚洲乱码中文字幕久久孕妇黑人| 亚洲激精日韩激精欧美精品| 精品丰满人妻无套内射| 狠久久av成人天堂| 久久精品无码中文字幕| 亚洲激情社区| 国产96在线 | 亚洲| 伊人久久亚洲影院| 成人免费aaa| 亚洲欧美大片| 色综合手机在线| 久久精品国产99久久6| 亚洲性图一区二区| 国内欧美视频一区二区| 欧美一级免费在线| 粉嫩aⅴ一区二区三区四区| 东京热av一区| 久久午夜免费电影| 亚洲精品成人av久久| 中文字幕一区二区三区蜜月 | 国产乱淫av麻豆国产免费| 国产aⅴ综合色| 久久久久久久无码| 久久久久久久久岛国免费| 国产18无套直看片| 亚洲免费视频成人| 国产福利久久久| 色综合网色综合| 伊人网免费视频| 日韩欧美国产综合一区| 无码精品视频一区二区三区| 亚洲欧美中文日韩在线| 日本免费在线观看| 色综合91久久精品中文字幕 | 91官网在线免费观看| 最新国产中文字幕| 日韩一区二区免费在线电影| 人人妻人人澡人人爽精品日本| 日韩精品极品视频免费观看| 成人网视频在线观看| 欧美成人免费va影院高清| 热三久草你在线| 国产日韩专区在线| 国产精品xxx在线观看| 欧美一区二区福利| 欧美一区不卡| 男人天堂网视频| 狠狠色丁香婷婷综合| 最近中文字幕无免费| 亚洲国产成人在线| 福利一区二区三区四区| 欧美中文字幕不卡| 亚洲精品久久久久久无码色欲四季 | 国产高潮视频在线观看| 国产日本欧美一区二区| 劲爆欧美第一页| 欧美视频一区二区三区在线观看 | 99久久免费视频.com| 亚洲综合图片一区| 欧美体内谢she精2性欧美| 国产精品色综合| 亚洲欧美国产一区二区三区| 伊人精品影院| 国产中文欧美精品| 亚洲自拍都市欧美小说| 精品无码av无码免费专区| 日韩和的一区二区| 波多野结衣视频播放| |精品福利一区二区三区| 国产区一区二区三| 欧美不卡视频一区| 欧美激情视频在线播放| 日本高清+成人网在线观看| 亚洲国产欧美国产第一区| 先锋影音日韩| 欧美综合二区| 日本黄色录像片| 一区二区三区中文字幕电影| 中文区中文字幕免费看| 日韩精品极品在线观看播放免费视频| 黄黄的网站在线观看| 国产精品久久久久久亚洲影视| 牛牛影视久久网| 国产精品亚洲天堂| 麻豆精品在线视频| 欧美 日韩 成人| 欧美性69xxxx肥| 午夜视频在线免费播放| 欧美激情亚洲一区| 无码国模国产在线观看| 午夜啪啪免费视频| 麻豆精品新av中文字幕| 国产综合精品在线| 色婷婷综合久久久中文一区二区| 蜜臀久久99精品久久久| 久久久久久91| av成人综合| 久久国产精品网| 成人黄色国产精品网站大全在线免费观看| 91嫩草|国产丨精品入口| 5566中文字幕一区二区电影| 午夜不卡视频| 亚洲一区二区三区毛片| 亚洲乱码免费伦视频| 午夜激情视频网| 一区二区欧美精品| 性网爆门事件集合av| 欧美黑人又粗大| 久久99国产精品久久99大师| 欧美午夜小视频| 伊人在我在线看导航| 综合久久亚洲| 爱豆国产剧免费观看大全剧苏畅| 国产欧美一区二区精品性| 成人黄色片在线观看| 日韩在线观看免费网站| 亚洲人体在线| 大陆极品少妇内射aaaaaa| 国产69精品久久99不卡| 国产精品免费av一区二区| 亚洲男人第一网站| 精品乱码一区二区三区四区| 伊人久久大香线蕉成人综合网| 国产一区激情在线| 国产亚洲成人精品| 日韩精品视频在线观看免费| 成人开心激情| 中文字幕日韩一区二区三区| 国产一区999| 日本在线小视频| 亚洲色图15p| 只有精品亚洲| 日韩一级片免费视频| gogogo免费视频观看亚洲一| 国产精品一区无码| 久久偷看各类女兵18女厕嘘嘘| 2021年精品国产福利在线| 无码aⅴ精品一区二区三区浪潮| 日本一区二区综合亚洲| xxxwww在线观看| 日本国产一区二区三区| 国产精品成人一区二区不卡| 国产精品嫩草69影院| 一本色道久久加勒比精品 | www国产亚洲精品久久麻豆| 精品国产青草久久久久96| 欧美精品在线观看91| 亚瑟一区二区三区四区| 天天做天天干天天操| 午夜激情久久久| 欧美性videos| 精品在线视频一区二区三区| 美女网站一区二区| 免费看日韩毛片| 毛片精品免费在线观看| 亚洲天堂日韩在线| 日本一区二区三区在线免费观看| 第一福利永久视频精品| 国产婷婷视频在线| 欧美一区二区三区精美影视| 国产99精品国产| 亚洲天堂avav| 欧美亚洲伦理www|