免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
楼主: iw1210
打印 上一主题 下一主题

[C] 用select做服务器,8G内存做到30万~50万客户同时在线 [复制链接]

论坛徽章:
324
射手座
日期:2013-08-23 12:04:38射手座
日期:2013-08-23 16:18:12未羊
日期:2013-08-30 14:33:15水瓶座
日期:2013-09-02 16:44:31摩羯座
日期:2013-09-25 09:33:52双子座
日期:2013-09-26 12:21:10金牛座
日期:2013-10-14 09:08:49申猴
日期:2013-10-16 13:09:43子鼠
日期:2013-10-17 23:23:19射手座
日期:2013-10-18 13:00:27金牛座
日期:2013-10-18 15:47:57午马
日期:2013-10-18 21:43:38
31 [报告]
发表于 2013-11-28 15:58 |只看该作者
yulihua49 发表于 2013-11-28 15:53
一点历史都不懂,select才是老爷车。
我用32进程处理,你用300-500个进程,哪个开销大?


你看看这个帖子基本上只有你在回复

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
32 [报告]
发表于 2013-11-28 16:01 |只看该作者
本帖最后由 yulihua49 于 2013-11-28 16:02 编辑
iw1210 发表于 2013-11-28 15:58
select是老,但使用得当威力无比。
你32进程各个忙得要死,开销不大?

相同业务量下,我的系统附加开销比你小得多。
线程忙比进程忙,轻松多了。
线程调度一次,3-7微秒,进程是20-50微秒。
还有,select激活后,要寻找fd,epoll没这个过程。

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
33 [报告]
发表于 2013-11-28 16:04 |只看该作者
hellioncu 发表于 2013-11-28 15:58
你看看这个帖子基本上只有你在回复

别人不感兴趣。

论坛徽章:
0
34 [报告]
发表于 2013-11-28 16:05 |只看该作者
本帖最后由 iw1210 于 2013-11-28 16:06 编辑
yulihua49 发表于 2013-11-28 16:01
相同业务量下,我的系统附加开销比你小得多。
线程忙比进程忙,轻松多了。
线程调度一次,3-7微秒,进程 ...

进程调度的开销是比线程大,但这些都可忽略不计,更何况计算机运行速度发展如此迅速。扩展能力和灵活方便才是主要考虑的。

论坛徽章:
0
35 [报告]
发表于 2013-11-28 16:05 |只看该作者
hellioncu 发表于 2013-11-28 15:58
你看看这个帖子基本上只有你在回复

兄台有何高见?

论坛徽章:
0
36 [报告]
发表于 2013-11-28 16:07 |只看该作者
yulihua49 发表于 2013-11-28 16:04
别人不感兴趣。

很多人不懂其中奥妙

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
37 [报告]
发表于 2013-11-28 16:08 |只看该作者
iw1210 发表于 2013-11-28 15:58
select是老,但使用得当威力无比。
你32进程各个忙得要死,开销不大?
数据库连接能力是数据库的事了, ...

数据库每个连接都需要N Mb,一般不希望连接过多,所以才有数据库连接池的技术。
不过ORACLE 11 开始支持库内的连接池,我没用过,你得试试。

论坛徽章:
0
38 [报告]
发表于 2013-11-28 16:11 |只看该作者
yulihua49 发表于 2013-11-28 16:01
select激活后,要寻找fd,epoll没这个过程 ...


寻找是必须的,各线程在各自的小范围内寻找,延迟可以忽略了

论坛徽章:
0
39 [报告]
发表于 2013-11-28 16:13 |只看该作者
回复 37# yulihua49
是的,数据库链接数的能力不应该是个瓶颈,我们不必要担心这个,是吧

论坛徽章:
15
射手座
日期:2014-11-29 19:22:4915-16赛季CBA联赛之青岛
日期:2017-11-17 13:20:09黑曼巴
日期:2017-07-13 19:13:4715-16赛季CBA联赛之四川
日期:2017-02-07 21:08:572015年亚冠纪念徽章
日期:2015-11-06 12:31:58每日论坛发贴之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-08-04 06:20:00程序设计版块每日发帖之星
日期:2015-07-12 22:20:002015亚冠之浦和红钻
日期:2015-07-08 10:10:132015亚冠之大阪钢巴
日期:2015-06-29 11:21:122015亚冠之广州恒大
日期:2015-05-22 21:55:412015年亚洲杯之伊朗
日期:2015-04-10 16:28:25
40 [报告]
发表于 2013-11-28 16:13 |只看该作者
本帖最后由 yulihua49 于 2013-11-28 16:21 编辑
iw1210 发表于 2013-11-28 16:05
进程调度的开销是比线程大,但这些都可忽略不计,更何况计算机运行速度发展如此迅速。扩展能力和灵活方便 ...

实际上,我的方案是什么都不用,在主机上,如IBM、HP、solaris,我只用TPC,每个连接一个线程,根本不用select,libevent什么的。死收死发,同步的数据库访问。
外边搭配交易管理器,管理大量客户。我跟你说的方案基本是交易管理器的方案。

32进程(3、50万客户端),弄百十来个连接到小型机,小型机可以3、50个数据库就够了。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP