国产精品电影_久久视频免费_欧美日韩国产激情_成年人视频免费在线播放_日本久久亚洲电影_久久都是精品_66av99_九色精品美女在线_蜜臀a∨国产成人精品_冲田杏梨av在线_欧美精品在线一区二区三区_麻豆mv在线看

建設一個靠譜的火車票網上訂購系統

系統
春節將到,大家買不著車票,趕不上大年三十與家人團聚,急切心情可以理解。但是拍桌子開罵,只能宣泄情緒,解決不了實際問題。開發一套訂票系統并不難,難在應對春運期間,日均 10 億級別的洪峰流量。日均 10 億級別的洪峰請求,在中國這個人口全球第一大國,不算稀罕,不僅火車票訂票系統會遇到,而且電子商務在促銷時,也會遇到,社交網站遇到新聞熱點時,也會遇到。

春節將到,大家買不著車票,趕不上大年三十與家人團聚,急切心情可以理解。但是拍桌子開罵,只能宣泄情緒,解決不了實際問題。

開發一套訂票系統并不難,難在應對春運期間,日均 10 億級別的洪峰流量。日均 10 億級別的洪峰請求,在中國這個人口全球第一大國,不算稀罕,不僅火車票訂票系統會遇到,而且電子商務在促銷時,也會遇到,社交網站遇到新聞熱點時,也會遇到。

所以,能夠在中國成功運行的云計算系統,推廣到全球,一定也能成功。但是在美國成功運行的云計算系統,移植到中國,卻不一定成功。

如果我們能夠設計建造一套,穩定而高效的鐵路訂票系統,不僅解決了中國老百姓的實際問題,而且在全球高科技業界,也是一大亮點,而且是貼著中國標簽的前沿科技的亮點。

于是軟件工程師們獻計獻策,討論如何改進 12306 網上購票系統 [3]。其中比較有代表性的,有兩篇 [4,5]。

網友的評論中,有觀點認為,[4] 利用“虛擬排隊”的手段,將過程拉長負載降低,是網游的設計思路。而 [5] 利用緩存技術,一層層地降低系統負荷, 是互聯網的設計思路。

個人認為,[4] 和 [5] 并不是相互排斥的兩種路線,兩者著重解決的問題不同,不妨結合起來使用,取長補短。下面介紹一下我們的設計草案,追求實用,擯棄花哨。拋磚引玉,歡迎拍磚。

 

 

 

 

圖一。12306.cn 網站系統架構設想圖。

Courtesy http://i879.photobucket.com/albums/ab351/kan_deng/12306.png

圖一是系統架構圖,典型的“展現層”/ “業務層”/ “數據層”的三段論。

用戶接入有兩類,一個是運行在電腦里的瀏覽器,例如 IE,另一個是手機。

無論用戶用電腦瀏覽器,還是手機訪問 http://www.12306.cn 網站,用戶請求首先被網站的負載均衡器接收。負載均衡器連接著一群門戶服務器,根據各個門戶服務器的負載輕重,負載均衡器把用戶請求,轉發到某一相對清閑的門戶服務器。

門戶服務器的任務類似于收發室老頭兒,它只讀每個用戶請求的前幾個 bytes,目的是確定用戶請求的類型,然后把請求投放到相應類型的隊列中去。門戶服務器的處理邏輯非常簡單,這樣做的好處,是讓它能夠快速處理大批量用戶請求。

根據 [5] 的分析,12306 處理的用戶請求,大致分為三類,

1. 查詢。用戶訂票前,查詢車次以及余票。用戶下訂單后,查詢是否已經訂上票。

2. 訂票,包括確定車次和票數,然后付款。用戶付款時,需要在網銀等網站上操作。

3. 第一次訪問的用戶,需要登記,包括姓名和信用卡等信息。

三類請求的業務處理過程,被分為兩個階段,

1. 運行于緩存中的任務隊列。設置隊列的目的,是防止處理過程耗時太長,導致大量用戶請求擁塞于門戶服務器,導致系統癱瘓。

2. 業務處理處理器,對于每一類業務,分別有一群業務服務器。不同業務的處理流程,各不相同。

 

 

 

 

圖二。12306.cn 網站查詢和訂票業務流程設想圖。

Courtesy http://i879.photobucket.com/albums/ab351/kan_deng/12306-1.png

圖二描述了查詢和訂票,兩個業務的處理流程。登記業務流程從略。

查詢的業務流程,參見圖二上半部,分五步。這里有兩個問題需要注意,

1. 用戶發出請求后,經過短暫的等待時間,能夠迅速看到結果。平均等待時間不能超過 1 秒。

2. 影響整個查詢速度的關鍵,是“查詢服務器”的設計。

查詢任務可以進一步細化,大致分成三種。

1. 查詢車次和時間表,這是靜態內容,很少與數據庫交互,數據量也不大,可以緩存在內存中。

車次和時間表的數據結構,不妨采用 Key-Value 的方式,開發簡單,使用效率高。Key-Value 的具體實現有很多產品,[5] 建議使用 Redis。

這些是技術細節,不妨通過對比實驗,針對火車票訂票系統的實際流量,以及峰值波動,確定哪一個產品最合適。

2. 查詢某一班次的剩余車票,這需要調用數據庫中不斷更新的數據。

[5] 建議把剩余車票只分為兩種,“有”或“無”,這樣減少調用訪問數據庫的次數,降低數據庫的壓力。但是這樣做,不一定能夠滿足用戶的需求,說不定會招致網友的批評譏諷。

[4] 建議在訂票隊列中,增加測算訂票隊列長度的功能,根據訂票隊列長度以及隊列中每個請求的購票數量,可以計算出每個車次的剩余座位。如果 12306.cn 網站只有一個后臺系統,這個辦法行之有效。

但是假如 12306.cn 網站采用分布式結構,每個鐵路分局設有子系統,分別管理各個鐵路分局轄區內的各個車次。在分布式系統下,這個辦法面臨任務轉發的麻煩。不僅開發工作量大,而且會延長查詢流程處理時間,導致用戶長久等待。

3. 已經下單的用戶,查詢是否已經成功地訂上票。

每個用戶通常只關心自己訂的票。如果把每個用戶訂購的車票的所有內容,都緩存在內存里,不僅非常耗用內存空間,內存空間使用效率低下,更嚴重的問題是,訪問數據庫過于頻繁,數據量大,增大數據庫的壓力。

解決上述分布式同步,以及數據庫壓力的兩個問題,不妨從訂票的流程設計和數據結構設計入手。

假如有個北京用戶在網上訂購了一套聯票,途經北京鐵路局和鄭州鐵路局轄區的兩個車次。用戶從北京上網,由北京鐵路局的子系統,處理他的請求。北京鐵路局的訂票服務器把他的請求一分為二,北京鐵路局的車次的訂票,在北京子系統完成,鄭州鐵路局的車次在鄭州子系統完成。

每個子系統處理四種 Key-Value 數據組。

1. 用戶ID:多個 (訂單ID)s。

2. 訂單ID:多個 (訂票結果ID)s。

3. 訂票結果ID: 一個 (用戶ID,車次ID)。

4. 車次ID:一個(日期),多個 (座位,用戶ID)。

北京訂票服務器完成訂票后,把上述四個數據組,寫入北京子系統的數據庫,同時緩存進北京的查詢服務器,參見圖二下半部第6步和第7步。

鄭州訂票服務器完成訂票后,把上述四個數據組,寫入鄭州子系統的數據庫,同時緩存進北京的查詢服務器,而不是鄭州的服務器。

讓訂票服務器把訂票數據,同時寫入數據庫和查詢服務器的緩存,目的是讓數據庫永久保留訂票記錄,而讓大多數查詢,只訪問緩存,降低數據庫的壓力。

北京用戶的訂票數據,只緩存在北京的查詢服務器,不跨域緩存,從而降低緩存空間的占用,和同步的麻煩。這樣做,有個前提假設,查詢用戶與訂票用戶,基本上是同一個人,而且從同一個城市上網。

但是這里有個缺陷,某用戶在北京上網訂了票。過了幾天,他在北京上網,輸入用戶ID和密碼后,就會看到他訂購的所有車票。可是又過了幾天,他去了鄭州,從鄭州上網,同樣輸入用戶ID和密碼,卻看不到他訂購的所有車票。

解決這個缺陷的辦法并不麻煩,在用戶查詢訂票信息時,需要注明訂票地點,系統根據訂票地點,把查詢請求轉發到相應區域的子系統。

另外,每次訂票的時候,網站會給他的手機發送短信,提供訂票信息,參見圖二下半部第8步和第9步。

以上是一個初步設計,還有不少細節需要完善,例如防火墻如何布置等等。這個設計不僅適用于單一的集中式部署,而且也適合分布式部署。

或許有讀者會問,為什么沒有用到云計算?其實上述架構設計,為將來向云計算演變,留下了伏筆。

在上述架構設計中,我們假定每個環節需要用多少服務器,需要多大容量的數據庫,預先都已經規劃好。但是假如事先的規劃,低于實際承受的流量和數據量,那么系統就會崩潰。所以,事先的規劃,只能以峰值為基準設立。

但是峰值將會是多少?事先難以確定。即便能夠確定峰值,然后以峰值為基準,規劃系統的能力,那么春運過后,就會有大量資源冗余,造成資源浪費?

如何既能抗洪,又不造成資源浪費?解決方案是云計算,而且目前看來,除了云計算,沒有別的辦法。

Reference,

[1] 海量事務高速處理系統。

http://www.douban.com/note/195179318/

[2] 去你媽的‘海量事務高速處理系統’。

http://weibo.com/1577826897/y0jGYcZfW

[3] 火車訂票系統的設想。

http://weibo.com/1570303725/y0l9Y2mwE

[4] 鐵路訂票系統的簡單設計。

http://blog.codingnow.com/2012/01/ticket_queue.html

[5] 鐵路訂票網站個人的設計淺見。

http://hi.baidu.com/caoz/blog/item/f4f1d7caee09b558f21fe780.html

【編輯推薦】

  1. 告別Win7?給你N個用云操作系統的理由
  2. 2012開年巨獻:一款來自德國的云OS
  3. 春節回家曬照片 ipad+快盤最給力
責任編輯:Yeva 來源: ifanr.com
相關推薦

2011-01-24 15:37:32

火車票

2012-01-05 09:14:05

Firefox

2016-08-31 13:26:24

PythonPython3工具

2012-01-05 13:14:42

火車票

2023-09-15 09:34:54

2011-01-28 15:48:11

Chrome插件Page Monito火車票

2018-01-10 22:19:44

2023-06-09 09:54:36

攜程工具

2019-04-26 15:16:02

馬蜂窩火車票系統

2018-12-29 16:24:58

Python12306火車票

2012-01-05 10:23:33

IE9預訂火車票

2023-07-07 14:18:57

攜程實踐

2011-01-21 15:53:31

火車票Sybase

2011-01-21 17:08:39

火車票

2012-11-15 09:40:18

2023-06-28 14:01:13

攜程實踐

2015-03-18 15:05:12

12306驗證碼

2022-09-09 15:49:03

攜程火車票組件化管理優化

2022-04-27 13:36:18

12306鐵路12306

2018-01-02 09:56:04

Python12306火車票
點贊
收藏

51CTO技術棧公眾號

一本色道久久综合| 精品久久中文字幕久久av| 国产日韩欧美夫妻视频在线观看| www.成人爱| 日韩欧美国产不卡| 国产对白叫床清晰在线播放| 亚洲一区在线视频| 8848hh四虎| 一区二区在线观看免费| wwwav91| 成人欧美一区二区三区白人 | 99久久综合狠狠综合久久止| 日韩精品导航| 2025国产精品视频| 日韩三级视频| 国产成人精品在线观看| 国产不卡一二三区| 国产免费一区视频观看免费 | 欧洲毛片在线| 中文字幕一区二区三| 国产精品嫩草影院久久久| 欧美久久一区二区三区| 丁香六月综合| 国产欧美日韩中文字幕在线| 女人天堂亚洲aⅴ在线观看| 欧美无砖专区一中文字| 国产资源在线播放| 欧美电影在线免费观看| 手机电影在线观看| 91精品国产色综合久久ai换脸 | 永久免费毛片在线播放不卡| 成人欧美一区二区三区的电影| 欧美在线看片| 国产成人精品电影久久久| 国产亚洲电影| 亚洲xxxxx电影| 18成人免费观看视频| 久久99欧美| 久色婷婷小香蕉久久| 欧美 日韩 亚洲 一区| 国产精品嫩草影院com| 影音先锋另类| 91精品中文字幕一区二区三区| av2020不卡| 久久国产视频网站| 色777狠狠狠综合伊人| 久久99精品国产99久久| 国产一区二区精品久久| 国产自偷自偷免费一区| 亚洲国产乱码最新视频 | 成人勉费视频| 欧美乱大交xxxxx| 视频在线不卡免费观看| 欧美一进一出视频| 2020国产精品自拍| 国产在线视频资源| 亚洲香蕉成人av网站在线观看| 青草伊人久久| 超碰97在线资源| 国产乱淫av一区二区三区| 91人人澡人人爽人人精品| 欧美日韩中国免费专区在线看| 搞黄网站在线看| 91精品成人久久| 美女久久一区| 孩娇小videos精品| 91麻豆精品久久久久蜜臀 | 日韩av在线网| 性欧美xxxx免费岛国不卡电影| 久久精品中文字幕一区二区三区| 不卡av免费在线观看| 在线观看的av网站| 日韩午夜在线视频| 男女激情无遮挡| 欧美日韩一二三四五区| 末成年女av片一区二区下载| 国产99久久精品一区二区 夜夜躁日日躁| 美女精品网站| 日本fc2在线观看| 亚洲天堂视频在线观看| 亚洲色图欧美| 香港日本韩国三级网站| 91精品福利在线一区二区三区 | 欧美成人a在线| 日韩欧美中文字幕电影| 先锋影音日韩| 偷拍与自拍一区| 4438五月综合| 色99中文字幕| 日韩欧美国产高清91| 视频精品二区| 中国一区二区三区| 欧美综合亚洲图片综合区| 一区二区三区国产好| 亚洲乱码一区二区三区| 日韩欧美亚洲范冰冰与中字| 国产精品一区二区三区av| 亚洲欧美日韩国产yyy| 欧美日韩免费在线观看| 97se亚洲| 人人妻人人澡人人爽欧美一区| 欧美日韩一级片在线观看| 狠狠操综合网| 天天干天天玩天天操| 国产亚洲精品日韩| 免费国产亚洲视频| 91社区在线| 成人午夜高潮视频| 一区二区三区在线观看网站| 国产综合色激情| 在线观看av的网址| 亚洲精品99久久久久| 久久精品91| 精品国产丝袜高跟鞋| 成人动漫视频在线观看免费| 亚洲国产综合视频在线观看| 人人精品视频| 男人艹女人在线观看| 欧美日本中文字幕| 97aⅴ精品视频一二三区| 色8久久影院午夜场| 伊人久久大香线蕉av一区| 日韩欧美一级片| 久久久久国产一区二区| 黄色在线免费看| 精品日产一区2区三区黄免费| 色婷婷av一区二区三区软件| 国产成人一区| 亚洲品质视频自拍网| 国产在线一区二区综合免费视频| av毛片在线看| 日本一区网站| 精品国产免费人成电影在线观看四季 | 日韩欧美在线中文字幕| 精品国产美女| 性欧美16一18| 国产美女91呻吟求| 欧美性猛交丰臀xxxxx网站| 7777久久香蕉成人影院| 国产在线资源| 欧美精品成人一区二区在线观看| 欧美日韩国产首页| 久久精品国产亚洲高清剧情介绍 | 亚洲黄色av女优在线观看| 麻豆久久精品| 碰碰在线视频| 国产一区二区网| 欧美激情一区二区三区久久久| 国产三级欧美三级| 欧美肉体xxxx裸体137大胆| 日本福利片高清在线观看| 国产精品大全| 精品成人私密视频| 99久精品国产| 国产一区二区三区四区| 黄视频在线观看免费| 亚洲巨乳在线观看| 美女少妇精品视频| 亚洲国产精品影院| 亚洲国产第一| 日韩电影免费观看高清完整版| 情侣黄网站免费看| 国产欧美精品一区二区| 欧美日韩国产综合久久| 丰满少妇久久久久久久| 色爱综合av| www久久日com| koreanbj精品视频一区| 国产成人aa精品一区在线播放| 欧美午夜影院在线视频| 男女男精品视频网| 51亚洲精品| 尤物在线视频| 免费在线观看毛片网站| 3d精品h动漫啪啪一区二区 | 久久综合九色综合97婷婷女人| 久草在线成人| 都市激情久久综合| 超碰成人福利网| 国产在线播放一区二区| 最近日韩中文字幕中文| 午夜激情久久久| 国产成人8x视频一区二区| 老司机午夜免费福利视频| 97免费中文视频在线观看| 色狠狠桃花综合| 99精品桃花视频在线观看| 婷婷六月综合| 免费高清视频在线一区| 超碰在线人人| 大陆av在线播放| 91久色国产| 欧美日韩第一页| 欧美va在线播放| 亚洲视频精选在线| 麻豆久久久久久| 天天综合久久| 国产成人tv| 性欧美1819sex性高清| 成人高清免费观看mv|