分布式高并發(fā)商品秒殺系統(tǒng)設(shè)計

分布式高并發(fā)商品秒殺系統(tǒng)設(shè)計

項目地址:https://github.com/Grootzz/dis-seckill

介紹

本項目為另一個項目seckill的分布式改進(jìn)版本翔悠,dis-seckill意為:distributed seckill饭寺,即分布式秒殺系統(tǒng)茎辐。

商品秒殺與其他業(yè)務(wù)最大的區(qū)別在于:

  • 低廉價格;
  • 大幅推廣峡扩;
  • 瞬時售空蹭越;
  • 一般是定時上架;
  • 時間短教届、瞬時并發(fā)量高响鹃、網(wǎng)絡(luò)的流量也會瞬間變大。

除了具有以上特點案训,秒殺商品還需要完成正常的電子商務(wù)邏輯茴迁,即:(1)查詢商品;(2)創(chuàng)建訂單萤衰;(3)扣減庫存堕义;(4)更新訂單;(5)付款脆栋;(6)賣家發(fā)貨倦卖。

本項目正是基于上述業(yè)務(wù)特點進(jìn)行設(shè)計的,在項目中引入諸多優(yōu)化手段椿争,使系統(tǒng)可以從容應(yīng)對秒殺場景下的業(yè)務(wù)處理怕膛。

另外,項目seckill為單體應(yīng)用秦踪,在大并發(fā)情形下處理能力有限褐捻,所以本項目對其進(jìn)行分布式改造,對職責(zé)進(jìn)行劃分椅邓,降低單體應(yīng)用的業(yè)務(wù)耦合性柠逞。

快速啟動

  • 構(gòu)建工具

    apache-maven-3.6.1

  • 開發(fā)環(huán)境

    JDK 1.8、Mysql 8.0.12景馁、SpringBoot 2.1.5板壮、zookeeper 3.4.10、dubbo 2.7.1合住、redis 5.0.5绰精、rabbitmq 3.7.15

在安裝之前,需要安裝好上述構(gòu)建工具和開發(fā)環(huán)境透葛,推薦在linux下安裝上述開發(fā)環(huán)境笨使。

第一步;完成數(shù)據(jù)庫的初始化僚害,使用./dis-seckill-common/schema/seckill.sql初始化數(shù)據(jù)庫硫椰。

第二步;如果安裝了git,則可以采用下面的方式快速啟動最爬;

git clone git@github.com:Grootzz/dis-seckill.git
mvn clean package

啟動用戶服務(wù):

jar dis-seckill-user/target/dis-seckill-user-0.0.1-SNAPSHOT.jar

啟動商品服務(wù):

jar dis-seckill-goods/target/dis-seckill-goods-0.0.1-SNAPSHOT.jar

啟動訂單服務(wù):

jar dis-seckill-order/target/dis-seckill-order-0.0.1-SNAPSHOT.jar

啟動緩存服務(wù):

jar dis-seckill-cache/target/dis-seckill-cache-0.0.1-SNAPSHOT.jar

啟動消息隊列服務(wù):

jar dis-seckill-mq/target/dis-seckill-mq-0.0.1-SNAPSHOT.jar

啟動網(wǎng)關(guān)服務(wù):

jar dis-seckill-gateway/target/dis-seckill-gateway-0.0.1-SNAPSHOT.jar

如果將項目導(dǎo)入IDE中進(jìn)行構(gòu)建涉馁,則分別按上面的順序啟動服務(wù)即可。

第三步爱致;訪問項目入口地址

http://localhost:8082/user/index

初始用戶手機(jī)號碼:18342390420烤送,密碼:000000

系統(tǒng)架構(gòu)

系統(tǒng)架構(gòu).png
  • 注冊中心使用zookeeper;
  • 緩存采用redis糠悯;
  • 詳細(xì)隊列采用RabbitMq帮坚;
  • 用戶請求全部交由Gateway模塊處理;
  • Gateway模塊使用RPC的方式調(diào)用其他模塊提供的服務(wù)完成業(yè)務(wù)處理互艾。

模塊介紹

  • dis-seckill-common:通用模塊
  • dis-seckill-user:用戶模塊
  • dis-seckill-goods:商品模塊
  • dis-seckill-order:訂單模塊
  • dis-seckill-gateway:網(wǎng)關(guān)模塊
  • dis-seckill-cache:緩存模塊
  • dis-seckill-mq:消息隊列模塊

TODO

  • [ ] 引入JWT簡化權(quán)限驗證试和;
  • [ ] 完成用戶注冊功能;
  • [ ] 引入分布式鎖保證更改密碼接口的冪等性纫普;
  • [ ] 服務(wù)模塊橫向擴(kuò)展阅悍;
  • [ ] 服務(wù)調(diào)用的負(fù)載均衡與服務(wù)降級;
  • [ ] gateway模塊橫向擴(kuò)展昨稼,降低單個應(yīng)用的壓力节视;
  • [ ] Nginx水平擴(kuò)展;
  • [ ] 接口壓測;
  • [ ] ......

參考

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末假栓,一起剝皮案震驚了整個濱河市寻行,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌匾荆,老刑警劉巖拌蜘,帶你破解...
    沈念sama閱讀 217,509評論 6 504
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異牙丽,居然都是意外死亡简卧,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,806評論 3 394
  • 文/潘曉璐 我一進(jìn)店門剩岳,熙熙樓的掌柜王于貴愁眉苦臉地迎上來贞滨,“玉大人,你說我怎么就攤上這事拍棕。” “怎么了勺良?”我有些...
    開封第一講書人閱讀 163,875評論 0 354
  • 文/不壞的土叔 我叫張陵绰播,是天一觀的道長。 經(jīng)常有香客問我尚困,道長蠢箩,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,441評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮谬泌,結(jié)果婚禮上滔韵,老公的妹妹穿的比我還像新娘。我一直安慰自己掌实,他們只是感情好陪蜻,可當(dāng)我...
    茶點故事閱讀 67,488評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著贱鼻,像睡著了一般宴卖。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上邻悬,一...
    開封第一講書人閱讀 51,365評論 1 302
  • 那天症昏,我揣著相機(jī)與錄音,去河邊找鬼父丰。 笑死肝谭,一個胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的蛾扇。 我是一名探鬼主播攘烛,決...
    沈念sama閱讀 40,190評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼屁桑!你這毒婦竟也來了医寿?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,062評論 0 276
  • 序言:老撾萬榮一對情侶失蹤蘑斧,失蹤者是張志新(化名)和其女友劉穎靖秩,沒想到半個月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體竖瘾,經(jīng)...
    沈念sama閱讀 45,500評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡沟突,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,706評論 3 335
  • 正文 我和宋清朗相戀三年,在試婚紗的時候發(fā)現(xiàn)自己被綠了捕传。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片惠拭。...
    茶點故事閱讀 39,834評論 1 347
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖庸论,靈堂內(nèi)的尸體忽然破棺而出职辅,到底是詐尸還是另有隱情,我是刑警寧澤聂示,帶...
    沈念sama閱讀 35,559評論 5 345
  • 正文 年R本政府宣布域携,位于F島的核電站,受9級特大地震影響鱼喉,放射性物質(zhì)發(fā)生泄漏秀鞭。R本人自食惡果不足惜趋观,卻給世界環(huán)境...
    茶點故事閱讀 41,167評論 3 328
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望锋边。 院中可真熱鬧皱坛,春花似錦、人聲如沸豆巨。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,779評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽搀矫。三九已至抹沪,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間瓤球,已是汗流浹背融欧。 一陣腳步聲響...
    開封第一講書人閱讀 32,912評論 1 269
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留卦羡,地道東北人噪馏。 一個月前我還...
    沈念sama閱讀 47,958評論 2 370
  • 正文 我出身青樓,卻偏偏與公主長得像绿饵,于是被迫代替她去往敵國和親欠肾。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,779評論 2 354