第378章【解决方案与报价】

下午。

罗晟依然待在蓝星科技集团,本来今天下午他要去蔚蓝海岸实验室主持一个技术会议的,不过在得知国家铁路集团前来寻求技术支持帮助,他临时修改了一下自己的工作安排,选择优先接见刘副总。

主要是年关将近,全国各地的民众尤其是外出务工的农民工都急着赶回家过年,这个群体非常不容易,罗晟觉得自己能为他们做点什么就做点什么,别的不说帮助他们更轻松的买到一张回家过年团聚的车票也是一件很有意义的事情。

况且还能收获一位大客户。

……

此时此刻,公司的一间会客室里,罗晟与刘副总等七八个国家铁路集团的人在一块。

简单见面寒暄了几句,刘副总找到重点话题的切入口,说道:“12306票务系统一期工程的开发费用合计三个亿,包含硬件,这套系统需要结合铁道部信息数据库、还需要结合电话售票、窗口售票等相关数据的结合。12306不是一个简单的在线交易系统,而是一个全国乃至世界最大的大宗物资货运系统。”

过了片刻,随行的一位技术专家也说道:“12306的技术确实非常难解决,利用现有的分布式数据库、缓存、负载均衡技术已经不能满足需求。”

说到这里,这名技术专家看向了罗晟补充道:“要知道,12306在春运的时候,日均有近300亿次访问量。如此天量级别的火车票查询是影响12306性能的重要原因之一,大概率占了90%以上的访问量。更及棘手的是:峰谷的查询有天壤之别,几乎没有办法在成本和并发能力之间做一个好的平衡。”

倾听着的罗晟默默的点点头,逝者对方把话说完之后,他便问道:“你们和阿里的合作是怎么解决的?”

那名技术专家坦言:“现在的做法是从几个关键入口流量控制,保障系统可用性,但是会影响用户体验,仍然出现网站宕机、打不开的现象,已经遭来一片骂声。”

说着那名技术专机也是苦笑的摇了摇头。

刘副总也说道:“阿里免费给12306提供技术支持,但是技术还是不够硬,我们现在就把希望放在星云上了。”

罗晟不由得一笑,也是耿直的说道:“刘总,首先我可以肯定的给你一个回复,星云系统完全没问题,同时我可以保证在一周之内就能实现为12306量身打造一整套从软件到硬件的完整解决方案,但这个解决方案不会像阿里一样免费支持。”

刘总哑然,也是一笑,道:“愿闻其详。”

罗晟思量了片刻,迅速组织好语言便说道:“如果星云支持12306系统以后,把12306网站查询访问放到星云上。一般而言,查询是多数售票系统访问量最大的部分,刚刚也听你们的专家说了,90%左右。在交易相关的过程中,都会多次提交查询请求,更不要说现在有大量刷票软件的出现所带来的额外增加的工作负载了,这一切都让余票查询系统成为整个系统的压力集中地。”

“我的解决方案是,星云介入后,把余票查询模块和12306现有系统做分离,具备独立部署的能力;在云端上独立部署一套余票查询系统,这样12306和云上都有了一套余票查询系统,调度会更为灵活,目前星云集群服务器规模已经达到了50000台以上。”

在场的几位铁路集团的技术专家一听也是暗暗咂嘴,难怪阿里的“飞天”系统这么不禁打,前者勉勉强强破千,而后者已经达到了5万规模之巨,难怪罗晟会这么有信心。

接下来,罗晟主要与铁路集团的几名技术专家讨论。

“今天上午我在得知消息顺带简单研究了一下‘12306’的服务端架构。”罗晟面向众人有条不紊的说道:“广大访问者都在喷,但是我知道12306服务一上线试运行,就承受着这个世界上任何秒杀系统都无法超越的QPS,上百万的并发再正常不过了。”

在场的几名铁路集团的技术骨干人员内心稀里哗啦的感动,理解万岁啊。

不懂技术的领导最难沟通,觉得没有尽力。

罗晟的话还是很有分量的。

过了片刻,罗晟补充道:“高并发的系统架构要采用分布式集群部署,服务上层有着层层负载均衡,并提供各种容灾手段,所谓的容灾手段就是双火机房、节点容错、服务器灾备等。保证系统的高可用,流量也会根据不同的负载能力和配置策略均衡到不同的服务器上。”

“即便如此,集群中的单机所能承受的QPS也是非常高的,那么如何将单机性能优化到极致呢?要解决这个问题要先弄明白一件事:通常订票系统要处理生成订单、减扣库存、用户支付这三个基本的阶段,系统要做的事情就是保证火车票订到不超卖、不少卖、每张售卖的车票都必须支付才有效,还要保证系统承受极高的并发。”

几名铁路集团的技术专家连连点头表示认同,技术痛点就在这里。

罗晟继续说道:“下单减库存。当用户并发请求到达服务端时,首先创建订单,然后扣除库存,等待用户支付。这种顺序是我们一般人首先会想到的解决方案,这种情况下也能保证订单不会超卖,但也会产生一些问题,第一就是在极限并发的情况下,任何一个内存操作的细节都至关影响性能,尤其是像创建订单这种逻辑,基本都需要存储到磁盘数据库的,对数据库的压力是可想而知的,12306应该是用的甲骨文数据库,别花这个冤枉钱了,放到我的星云上。”

“第二是如果用户存在恶意下单的情况,只下单不支付这样库存就会变少,会少卖很多订单,虽然服务端可以限制IP和用户的购买订单数量,但这也真心不算是一个好办法。”

“然后就是支付减库存了。如果等待用户支付了订单再减库存,第一感觉就是不会少卖。但这是并发架构的大忌,因为在极限并发的情况下,用户可能会创建很多订单,当库存减为零的时候很多用户会发现抢到的订单支付不了,这也就是所谓的‘超卖’,也不能避免并发操作数据库磁盘IO。”

“最后是预扣库存。从上面两种方案的考虑,可以得出结论:只要创建订单,就要频繁操作数据库IO。那么有没有一种不需要直接操作数据库IO的解决方案呢?答案是有,就是预扣库存,先扣除了库存,保证不超卖,然后异步生成用户订单,这样响应给用户的速度会快很多。”

“那么怎么保证不少卖呢?用户拿到了订单,不支付怎么办?订单都应该有效期,比如说用户五分钟内不支付,订单就失效,就会加入新的库存。订单的生成是异步的,应该放到即时消费队列中处理……”

刘副总听的云里雾里的,但是他发现罗晟和他带来的几个技术专家交流的愈发火热,似乎也得出了一个信息。

找对人了!

这时,罗晟打开了房间里的墙面上的大屏幕,他也拿来了一台笔记本工作电脑打开,示意众人看向主投屏,自己一边操作电脑一边说道:

“Go语言原生为并发设计,我就采用Go语言给各位演示一下单机抢票的具体流程以及我优化后的解决方案。”

“Go包中的init函数先于main函数执行,也在这个阶段主要做一些准备性质的工作。系统需要做的准备工作有:初始化本地库存、初始化远程redis存储统一库存的hash键值、初始化redis链接池。”

“另外还需要初始化一个大小为1的int类型chan,目的是实现分布式锁的功能,也可以直接使用读写锁或者使用redis等其他方式避免资源竞争,但是使用Channel更加高效,这就是Go语言的哲学,不需要通过共享内存来通信,而是通过通信来共享内存。Redis库使用的是redigo,下面是代码:

//localSpike包结构体定义

package localSpike

type LocalSpike struct {

LocalInStock int64

LocalSalesVolume int64

}

//remoteSpike对hash结构的定义和redis连接池

package remoteSpike

//远程订单存储健值

type RemoteSpikeKeys struct {

……

……

不知不觉,时间已经过去了一个半小时,反正刘副总是听不懂,那些代码看的晕头转向。

技术问题终于讨论的差不多了。

铁路集团的技术专家看向了刘副总并且带着肯定的目光轻点了一下头,刘副总立马就明白了,果断的转投看向罗晟问道:“罗总,如果提供这么一整套完善解决方案,报价是多少?”

罗晟直言:“每年支付10个亿。”

刘副总听到这个数字差点没有一口老血喷出来,12306票务系统一期工程的预算也才3个亿,这样的报价简直贵到难以接受。

……

第188章【手机还能做成这样?】第029章【秦微木】第288章【英特尔的不屑嘲讽[月票加更]】第937章【冲突升温】第896章【骗补贴、套项目的潜在问题(加餐)】第778章【小人物讲大格局】第054章【会面】第804章【扫货芯片与抛售美元计划】第042章【跨界?成立第二家独资公司?】第568章【55家证券公司联合保荐上市】第029章【秦微木】第102章【商业互吹】第423章【方舟即将起航,再不登船就等死吧】第028章【7700万】第241章【说的没错,就是站着说话不腰疼[2100票加更]】第351章【重新定义Azure】第160章【套现】第023章【VC投资的是整个赛道】第144章【三大联合保荐人】第817章【林加无人港开启运营】第745章【雷总:谢谢,感觉有被冒犯到】第550章【蔚蓝电动汽车发布会】第923章【初战告成】第481章【老张幸不辱命,欧元区市场保住了】第216章【傲娇?不听话就并购了】第322章【一个月要求花掉100个小目标】第124章【新一年的奋斗(3/4)】第501章【第一个不买罗晟的账的人】第395章【赤果果的炫耀,友商羡慕死的节奏】第390章【极紫外光刻技术模拟】第679章【就喜欢你看我不爽又奈何不了我的样子】第655章【“箭”在弦上,发射!】第336章【全面开花】第427章【制裁?难!】第628章【这个世界太蛮横不讲理】第678章【被折腾到苦不堪言的北美科技巨头们】第414章【一并给批了!】第217章【找个“爸爸”找个好“爸爸”】第905章【太空垃圾的系列处理方案】第972章【杨宁的实验报告】第965章【提前布局】第427章【制裁?难!】第948章【崩盘!崩盘!再崩盘!】第577章【价值投资布局与围剿QFII?】第400章【千金买马骨,内容自制计划】第239章【售价】第188章【手机还能做成这样?】第717章【五百亿美元经费转运难题】第081章【投前VC是大爷,投后我是大爷】第786章【急眼了的高通】第986章【惨烈激烈又激情的市场】第318章【实名客串】第794章【这就是大佬的格局高度嘛?】第099章【盖茨与谷歌进场】第962章【殴洲人的羡慕嫉妒】第1018章【抵达北美】第176章【精明的女人很靠谱[800月票加更]】第357章【首日销量与友商的羡慕嫉妒】第232章【未来十年之变】第699章【抄底,急速大反转】第340章【一个坏消息,老美的套路】第240章【席卷曰本】第669章【培植发育】第912章【太空制造业】第836章【外界的震惊与瞩目】第164章【时代真的变了(求订阅)】第556章【群魔乱舞?车还没上市就快被玩坏了?(两章合并)】第266章【芯片江湖的那点事儿】第931章【芯片囤积被曝光,再起轩然大波】第150章【上市倒计时[感谢“Sandy_M”的舵主]】第450章【别人贪婪时我恐惧,别人恐惧时我贪婪】第104章【赫利的疯狂点子】第724章【科技改变生活,创新改变世界】第680章【来自罗晟的灵魂拷问】第147章【精明到骨子里】第868章【世界顶级投资机构云集而来】第170章【姚建鸿的工作报告(月票加更)】第654章【人类的本质果然喜欢互相伤害】第722章【人造电子皮肤】第127章【开始买买买(2/4)】第938章【混乱加剧,史诗级拉闸】第110章【是合作还是竞争?】第619章【罗晟的回应】第919章【推至风口浪尖的晟峰资本】第758章【这售价,同行们直接吓到裂开】第485章【给华尔街一个惊喜】第619章【罗晟的回应】第293章【新挑战与新机遇】第699章【抄底,急速大反转】第196章【我要沽空这些债券】第571章【被大佬关注了】第515章【轰动世界,史诗级饕餮盛宴开始!】第815章【收割与抄底】第787章【远程视讯云谈判】第1003章【太空天梯:全球避险资金的新天堂】第932章【谈判,全球为之瞩目】第1024章【史诗级的分红规模】第1005章【等待已久时机到了】第879章【罗晟=财富密码】第653章【炸了炸了它炸了】
第188章【手机还能做成这样?】第029章【秦微木】第288章【英特尔的不屑嘲讽[月票加更]】第937章【冲突升温】第896章【骗补贴、套项目的潜在问题(加餐)】第778章【小人物讲大格局】第054章【会面】第804章【扫货芯片与抛售美元计划】第042章【跨界?成立第二家独资公司?】第568章【55家证券公司联合保荐上市】第029章【秦微木】第102章【商业互吹】第423章【方舟即将起航,再不登船就等死吧】第028章【7700万】第241章【说的没错,就是站着说话不腰疼[2100票加更]】第351章【重新定义Azure】第160章【套现】第023章【VC投资的是整个赛道】第144章【三大联合保荐人】第817章【林加无人港开启运营】第745章【雷总:谢谢,感觉有被冒犯到】第550章【蔚蓝电动汽车发布会】第923章【初战告成】第481章【老张幸不辱命,欧元区市场保住了】第216章【傲娇?不听话就并购了】第322章【一个月要求花掉100个小目标】第124章【新一年的奋斗(3/4)】第501章【第一个不买罗晟的账的人】第395章【赤果果的炫耀,友商羡慕死的节奏】第390章【极紫外光刻技术模拟】第679章【就喜欢你看我不爽又奈何不了我的样子】第655章【“箭”在弦上,发射!】第336章【全面开花】第427章【制裁?难!】第628章【这个世界太蛮横不讲理】第678章【被折腾到苦不堪言的北美科技巨头们】第414章【一并给批了!】第217章【找个“爸爸”找个好“爸爸”】第905章【太空垃圾的系列处理方案】第972章【杨宁的实验报告】第965章【提前布局】第427章【制裁?难!】第948章【崩盘!崩盘!再崩盘!】第577章【价值投资布局与围剿QFII?】第400章【千金买马骨,内容自制计划】第239章【售价】第188章【手机还能做成这样?】第717章【五百亿美元经费转运难题】第081章【投前VC是大爷,投后我是大爷】第786章【急眼了的高通】第986章【惨烈激烈又激情的市场】第318章【实名客串】第794章【这就是大佬的格局高度嘛?】第099章【盖茨与谷歌进场】第962章【殴洲人的羡慕嫉妒】第1018章【抵达北美】第176章【精明的女人很靠谱[800月票加更]】第357章【首日销量与友商的羡慕嫉妒】第232章【未来十年之变】第699章【抄底,急速大反转】第340章【一个坏消息,老美的套路】第240章【席卷曰本】第669章【培植发育】第912章【太空制造业】第836章【外界的震惊与瞩目】第164章【时代真的变了(求订阅)】第556章【群魔乱舞?车还没上市就快被玩坏了?(两章合并)】第266章【芯片江湖的那点事儿】第931章【芯片囤积被曝光,再起轩然大波】第150章【上市倒计时[感谢“Sandy_M”的舵主]】第450章【别人贪婪时我恐惧,别人恐惧时我贪婪】第104章【赫利的疯狂点子】第724章【科技改变生活,创新改变世界】第680章【来自罗晟的灵魂拷问】第147章【精明到骨子里】第868章【世界顶级投资机构云集而来】第170章【姚建鸿的工作报告(月票加更)】第654章【人类的本质果然喜欢互相伤害】第722章【人造电子皮肤】第127章【开始买买买(2/4)】第938章【混乱加剧,史诗级拉闸】第110章【是合作还是竞争?】第619章【罗晟的回应】第919章【推至风口浪尖的晟峰资本】第758章【这售价,同行们直接吓到裂开】第485章【给华尔街一个惊喜】第619章【罗晟的回应】第293章【新挑战与新机遇】第699章【抄底,急速大反转】第196章【我要沽空这些债券】第571章【被大佬关注了】第515章【轰动世界,史诗级饕餮盛宴开始!】第815章【收割与抄底】第787章【远程视讯云谈判】第1003章【太空天梯:全球避险资金的新天堂】第932章【谈判,全球为之瞩目】第1024章【史诗级的分红规模】第1005章【等待已久时机到了】第879章【罗晟=财富密码】第653章【炸了炸了它炸了】