免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12345
最近访问板块 发新帖
楼主: ideawu

[C++] [英雄贴]开发每日处理10亿请求的专用HTTP服务器 [复制链接]

论坛徽章:
2
技术图书徽章
日期:2013-09-04 15:21:51酉鸡
日期:2013-11-01 21:20:20
发表于 2013-08-16 15:02 |显示全部楼层
回复 39# ideawu

需求不能随着楼层增长而增长。依据starwing83的计算,11574 请求/秒,每请求更新100字节,不过才1M字节/s,对于memcache,还是足以应付。百万级的用户数据,现在的内存容量,也可以容纳。

memcache只是内存存储,不能完成复杂的top排序。而且业务统计可大可小。业务需求不定,如何能确定架构?
   

论坛徽章:
40
水瓶座
日期:2013-08-15 11:26:422015年辞旧岁徽章
日期:2015-03-03 16:54:152015年亚洲杯之乌兹别克斯坦
日期:2015-03-27 14:01:172015年亚洲杯之约旦
日期:2015-03-31 15:06:442015亚冠之首尔
日期:2015-06-16 23:24:37IT运维版块每日发帖之星
日期:2015-07-01 22:20:002015亚冠之德黑兰石油
日期:2015-07-08 09:32:07IT运维版块每日发帖之星
日期:2015-08-29 06:20:00IT运维版块每日发帖之星
日期:2015-08-29 06:20:00IT运维版块每日发帖之星
日期:2015-10-10 06:20:00IT运维版块每日发帖之星
日期:2015-10-11 06:20:00IT运维版块每日发帖之星
日期:2015-11-10 06:20:00
发表于 2013-08-16 15:20 |显示全部楼层
你前半句还真说对了 有钱的确可以搞出来这些公司 甚至还可以收购这些公司

这个基本上就是钱的问题 问题不在于硬件服务器 在国内的最现实的还是带宽问题 每秒钟上万的请求 假设每个请求50K,这需要多少带宽啊~~~

阿里云1M/年 700左右 这费用还是比较要命的~~

回复 7# ideawu


   

论坛徽章:
40
水瓶座
日期:2013-08-15 11:26:422015年辞旧岁徽章
日期:2015-03-03 16:54:152015年亚洲杯之乌兹别克斯坦
日期:2015-03-27 14:01:172015年亚洲杯之约旦
日期:2015-03-31 15:06:442015亚冠之首尔
日期:2015-06-16 23:24:37IT运维版块每日发帖之星
日期:2015-07-01 22:20:002015亚冠之德黑兰石油
日期:2015-07-08 09:32:07IT运维版块每日发帖之星
日期:2015-08-29 06:20:00IT运维版块每日发帖之星
日期:2015-08-29 06:20:00IT运维版块每日发帖之星
日期:2015-10-10 06:20:00IT运维版块每日发帖之星
日期:2015-10-11 06:20:00IT运维版块每日发帖之星
日期:2015-11-10 06:20:00
发表于 2013-08-16 15:21 |显示全部楼层
这是个好主意 非核心业务就放到队列中慢慢跑好了



回复 32# koolcoy


   

论坛徽章:
17
处女座
日期:2013-08-27 09:59:352015亚冠之柏太阳神
日期:2015-07-30 10:16:402015亚冠之萨济拖拉机
日期:2015-07-29 18:58:182015年亚洲杯之巴勒斯坦
日期:2015-03-06 17:38:17摩羯座
日期:2014-12-11 21:31:34戌狗
日期:2014-07-20 20:57:32子鼠
日期:2014-05-15 16:25:21亥猪
日期:2014-02-11 17:32:05丑牛
日期:2014-01-20 15:45:51丑牛
日期:2013-10-22 11:12:56双子座
日期:2013-10-18 16:28:17白羊座
日期:2013-10-18 10:50:45
发表于 2013-08-16 17:14 |显示全部楼层
回复 1# ideawu


    把在线状态服务器从后台移到前台?如果是单台服务器那么这就成为一个瓶颈了更严峻的是因为直接暴露给浏览器那么万一遇到攻击这个服务太容易瘫痪了,否则就需要集群又回到你之前说的需要同步的问题上了。所以把这个服务器移到前端必然有load balance问题存在而且还需要考虑到CDN缓存访问的问题,我觉得把这个服务移到前台比放到后台引入了更多的问题,并不值的这么作。

论坛徽章:
5
狮子座
日期:2013-08-20 10:12:24午马
日期:2013-11-23 18:04:102015年辞旧岁徽章
日期:2015-03-03 16:54:152015亚冠之德黑兰石油
日期:2015-06-29 18:11:1115-16赛季CBA联赛之新疆
日期:2024-02-21 10:00:53
发表于 2013-08-16 17:57 |显示全部楼层
回复 39# ideawu


    所谓序列化倒不一定要在值上玩花样,确切地说,在key上玩花样是最好的:

memcached["id_1234567.1234.1234"] = xxxx;

论坛徽章:
3
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:58:11数据库技术版块每日发帖之星
日期:2015-08-30 06:20:00
发表于 2013-08-24 21:46 |显示全部楼层
不得不说, libuv 是一个非常糟糕的, 垃圾透顶的库.

为啥这么说呢? 因为 uv_write 允许 NULL 回调! 鼓励忽略 write 的返回值! 鼓励编写面条代码, 垃圾代码就这样被 libuv 鼓励出来了.

uv_write 为啥允许 NULL 回调呢? 因为 以前 libuv 的 uv_write 是没有回调也没有返回值的 , 你永远不知道发送成功了没. 后来大概作者意识到这个问题了, 就添加了 回调....

然后估计是为了方便代码迁移吧, 允许 NULL 回调, 这样原来的代码加个 NULL 参数就继续工作了 ......

这写库是写着玩的吧?
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP