需要做个支持两万并发的抢购程序,只有一台服务器

2014-11-13 07:35:28 +08:00
 zaishanfeng
瞬间并发量能达到两万,服务器四核8g,备选语言php python,求方案
13734 次点击
所在节点    问与答
62 条回复
wzxjohn
2014-11-13 07:36:26 +08:00
黄牛你好。
zaishanfeng
2014-11-13 07:37:42 +08:00
@wzxjohn 怎么是黄牛?
msg7086
2014-11-13 07:52:39 +08:00
并发两万是什么概念?

瞬时连接数到两万的话,建议考虑基于event模型的架构,比如openresty。

PHP的瞬时连接数能到500就不错了。
abelyao
2014-11-13 07:53:05 +08:00
@wzxjohn 以为你要去抢别人
zaishanfeng
2014-11-13 07:54:32 +08:00
@msg7086 客户需求是这样的 要求达到瞬间两万 现在考虑用hhvm 候选golang
zjxubinbin
2014-11-13 07:56:03 +08:00
Gunicorn+gevent
coldwinds
2014-11-13 07:58:24 +08:00
swoole
msg7086
2014-11-13 07:58:52 +08:00
@zaishanfeng hhvm跟不上的吧。
顺便一提,都瞬间并发2万的,最起码得来个几十万的资金支持吧。
瞬间2万,每个请求假定是100ms,那就是每秒20万请求,每天至少能跑170亿请求。
京东这级别的都不知道平时有没有并发2万。
RemRain
2014-11-13 07:59:56 +08:00
PHP 是进程或者线程模型,一个线程同时只能处理一个请求,并发两万个线程能要了 server 的命。除非用 PHP 裸写 socket,用 pool 或者 epoll 模型才有一点希望
goofansu
2014-11-13 08:00:56 +08:00
数据库才是瓶颈
zaishanfeng
2014-11-13 08:02:36 +08:00
@msg7086 这个是临时需求 他们不愿意花钱买服务器
zaishanfeng
2014-11-13 08:03:11 +08:00
@goofansu 这个级别server也是瓶颈
zaishanfeng
2014-11-13 08:04:24 +08:00
也许nginx + lua可以扛得住?
zaishanfeng
2014-11-13 08:07:24 +08:00
据我估计他们真实并发能有五六千就不错了,可是客户很强硬,搞死我了,哎
abelyao
2014-11-13 08:07:37 +08:00
@zaishanfeng 了解一下实际可能的访问量,有时候客户尽会瞎扯,浪费了许多时间去滥开发
changsha
2014-11-13 08:09:13 +08:00
都在bb 能不能给点实际的?
zaishanfeng
2014-11-13 08:09:59 +08:00
@abelyao 他们前期推广做的比较好,到时候抢购的人应该会比较多
msg7086
2014-11-13 08:11:36 +08:00
@zaishanfeng 加钱嘛?

nginx+lua的速度还是不错的,基本都异步而且开发应该也不算太麻烦。

特别是如果请求和返回值不要求严格一致的话,还可以扔进redis队列里慢慢处理。

之前写了个简单的bt tracker,每秒250请求在一台i3上基本看不出CPU占用。
serco
2014-11-13 08:13:17 +08:00
@zaishanfeng 必须event IO模型才可能,语言限定的话
abelyao
2014-11-13 08:13:25 +08:00
@zaishanfeng 其实就是文字上的表述问题,例如 “每分钟处理20000次请求” 听起来也是 “瞬间”,但平均下来每秒只要处理大约 333 次就可以了,具体还是要看实际访问量+沟通吧,如果真的是每秒 20000 次请求,不加钱别谈了,这么大的项目还这么吝啬。

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/146057

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX