其实铁路订票系统面临的技术难点无非就是春运期间可能发生的海量并发业务请求。这个加上一个排队系统就可以轻易解决的。

本来我在 weibo 上闲扯两句,这么简单的方案,本以为大家一看就明白的。没想到还是许多人有疑问。好吧,写篇 blog 来解释一下。

简单说,我们设置几个网关服务器,用动态 DNS 的方式,把并发的订票请求分摊看。类比现实的话,就是把人分流到不同的购票大厅去。每个购票大厅都可以买到所有车次的票。OK ,这一步的负载均衡怎么做我就不详细说了。

每个网关其实最重要的作用就是让订票的用户排队。其实整个系统也只用做排队,关于实际订票怎么操作,就算每个网关后坐一排售票员,在屏幕上看到有人来买票,输入到内部订票系统中出票,然后再把票号敲回去,这个系统都能无压力的正常工作。否则,以前春运是怎么把票卖出去的?

我们来说说排队系统是怎么做的:

其实就类似我们去热门馆子吃饭拿号。只不过要防止别人伪造号插队而已。

如果你来一个人(一次 HTTP 请求),我就随机产生一个我做过一些签名处理的号码返回给你。暂时称为 ticket id 。这个 ticked id 是很难伪造的。

系统在内存里开一个大数组(32G 内存够排上亿人了吧),就是一循环队列。把这个 ticket id 放在队列尾。

用户现在拿着 ticket id 向网关发起请求。网关利用一次 hash 查询,在内存中的数组队列里查到它的位置,立刻返回给用户。用户的前端就可以看到,他在这个网关(售票大厅)前面还有多少人等着。

这里的关键是,整个队列都在本机的内存中,查询返回队列中的位置,可以实现的比一个处理静态文件的 web server 还要高效。静态文件至少还要去调用文件 IO 呢。静态文件 web server 可以处理多少并发量,不用我介绍了。

同时,前端会控制用户拿着 ticket id 查询队列位置的频率。高负载时可以 1s 一次,甚至更长时间。为了防止用户自己写脚本刷这个请求(虽然没有太大意义,因为刷的多也不会排到前面去),如果见到同一个 ticket id 过于频繁的查询。比如 10s 内查询了 20 次以上。就直接把这个 ticket id 作废。持有这个 ticket 的人就需要重新排队了。

对于最后排到的人,系统会生成一个唯一的不可伪造的 session id ,用户下面就可以通过这个 session id 去做实际的购票流程了。可以连去真正的购票服务器,也可以通过网关中转。非法的 session id 会立刻断掉,用户一旦知道伪造 session id 几乎不可能,只有通过 ticket id 排队拿到,除非是恶意攻击系统,不然不会有人乱拿 session id 去试。

我们再给每个 session id 设置一个最长有效时间,比如半小时。如果超过半小时还没有完整购票流程,那么就重新去排队。

至于同时开放多少个 session id ,也就是相当于开放多少个购票窗口,就取决于购票系统能承受的负载了。不过简单计算一下,就知道有排队系统保证了良好的次序,再以计算机的吞吐能力,解决不过几亿人的购票请求,即使这些人都同来排队,也就是一组机器几小时的处理量而已。

这票 blog 也就是随便写写,可能不太严谨,但意思达到了。中间有很多数据需要估算,也不是太难的事情。

为什么现在的购票系统这么滥?关键在于大量的网络带宽,计算力浪费在了“维持次序”上。系统不稳定时,大量的只做了一半的无效的购票流程浪费掉了这些。要响应高并发的 HTTP 请求,关键就在于迅速反应,不要什么都想着从数据库绕一圈。排队的队伍维持就完全不需要使用数据库。如果所有 HTTP 请求都立刻返回,在短时间内可以处理的 HTTP 请求量也会非常大。而如果你一下处理不了这个请求,又把 TCP 连接保持在那里,就莫怪系统支持不住了。

另外,用户看到了不断在减少的队列前面的人数,他们也会安心等待。只要网站页面刷新流畅(只处理队列信息很容易保证),用户体验会很好。

转载自: 云风的 BLOG  铁路订票系统的简单设计

转载于:https://www.cnblogs.com/wufawei/archive/2012/01/11/2320029.html

铁路订票系统的简单设计(转载)相关推荐

  1. 铁路订票网站,网友设计整理

    [size=medium][b]整理如下,供大家参考:[/b][/size] [url=http://blog.codingnow.com/2012/01/ticket_queue.html][siz ...

  2. 假如我是铁路订票系统架构师系列 - 开放还是封闭系统 - 对外挂的态度

    今年铁路订票系统的热门话题是抢票插件. 从铁道部不允许电商代购看,业务上要求订票系统应该是设计成封闭系统.但订票系统能让别人开发出抢票软件,说明没有有意将其设计成封闭系统. 这是典型架构师没有完全实现 ...

  3. 从铁路订票系统问题看系统架构师的责任和水平

    据新闻报道铁路订票系统采用了排队系统,但排队时间需要30分钟.使很多人不满. 并且系统仍然有登陆不上的问题. 从描述看,系统很可能采用了本博客前面提到的异步处理架构. 但从用户体验看该系统架构师的设计 ...

  4. win API之航空客运订票系统(课程设计)

    这学期的数据结构课结了,上个周做了课程设计,在此总结下(晒一下) 先是老师给了选题,我选了航空客运订票系统这个选题. 这个系统定义的也很简单,就是两个单链表,一个航班的,一个顾客的,再对它俩进行遍历. ...

  5. 由铁路订票系统联想到的

    作为一个互联网初哥这样级别飙升的流量,居然还能让大把的人定到票,可想而知:要么是所谓的高流量网站技术太简单:要么是铁道部信息技术中心太NB.真相到底是什么呢?我个人以为,两边都沾着那么一点. 中国铁路 ...

  6. 12306铁路订票系统的一个小bug

    进入12306的后台>>打开[我的信息]>>打开[常用联系人] 列表中上面是自己不能修改,下面是帮别人买票时自动添加上的联系人点击[编辑] 进入到的页面可以修改用户信息,生日默 ...

  7. 火车时刻表C语言报告,终稿火车订票系统的设计与实现课程设计.doc最终版(范文1)...

    <火车订票系统的设计与实现课程设计.doc>由会员分享,可免费在线阅读全文,更多与<(终稿)火车订票系统的设计与实现课程设计.doc(最终版)>相关文档资源请在帮帮文库(www ...

  8. 说说12306.cn铁路订票网站

    铁路订票网站常常挂掉,那些技术宅们又有写头了.对技术的选用比如caoz写的这篇,再如对架构的设计云风写的这篇.我这篇是扯蛋打酱油的.如果想看技术分析请看caoz和云风的. 1,What is key ...

  9. spring boot火车订票系统 毕业设计源码031012

    火车订票系统的设计与实现 摘 要 信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题. ...

  10. (附源码)spring boot火车票订票系统 毕业设计171538

    火车票订票系统的设计与实现 摘 要 信息化社会内需要与之针对性的信息获取途径,但是途径的扩展基本上为人们所努力的方向,由于站在的角度存在偏差,人们经常能够获得不同类型信息,这也是技术最为难以攻克的课题 ...

最新文章

  1. 全局负载均衡与CDN内容分发
  2. uniapp中easycom组件的封装
  3. java match正则不生效_[Java教程]正则表达式match()函数
  4. 项目如何用jetty运行_如何用Cloudbase Framework部署一个Vue项目?
  5. oracle 去重_超详细的四类数据库去重实现方案汇总,值得收藏
  6. Phonetics: Lecture Three 语音 第三课 Teacher:Patrick
  7. php java session共享_PHP实现多服务器session共享之NFS共享
  8. [转载] 机器学习 - 如何使用 Java 调取 Python、R 的训练模型?
  9. 【Linux】scp IT IS POSSIBLE THAT SOMEONE IS DOING SOMETHING NASTY!
  10. NYOJ水题--最短街区问题
  11. 2022最新版VMware虚拟机及CentOS-7安装教程
  12. 清华同方台式计算机 U盘启动,清华同方台式机BIOS设置U盘启动方法
  13. java 图片 白边,如何在Java中自动裁剪图像白色边框?
  14. 弘辽科技:6个核心关键词,抓住创业的“命运转折点”!
  15. Windows防火墙开关及入站规则
  16. 办公实用资源网站分享,每一款都能让你升职加薪
  17. IOS 插屏广告弹窗
  18. Linux监控平台介绍
  19. NLP初学-Word Segmentation(分词)
  20. 京训钉怎么快速看完_阿里(钉钉部门)远程面,三面坐上“直通车”,拿下offer没问题...

热门文章

  1. C盘压缩,电脑无法正常启动的解决方法?
  2. 日语常用口语1000句
  3. 【推荐】到伊甸园玩体感游戏吧!
  4. 过计算机管理共享文件夹,局域网中怎么查看自己共享过的文件
  5. 惯性力偶矩公式中j_惯性力偶矩的计算
  6. 台式计算机如何上无线网络,台式机如何无线上网
  7. 魏尔斯特拉斯---严谨的典范
  8. eq linux_Pr音频效果参考:滤波器与EQ
  9. DeFi冰火两重天:数千项目,鲜有人用,存量厮杀如何撼动传统金融?
  10. 医疗时钟系统的设计方案