免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
12下一页
最近访问板块 发新帖
查看: 6362 | 回复: 10
打印 上一主题 下一主题

请教大牛:异步io的优点究竟在哪 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2013-01-16 12:53 |只看该作者 |倒序浏览
在考虑服务器通讯模型的问题,究竟何种情况下异步io模型相对同步io模型有较大的优势?原因是什么?是同步io为了应付大并发量必须派生大量线程导致上下文切换过多造成的吗(似乎有些场景并不能完全证明这点)?

Note:
我问的不是阻塞模型和非阻塞模型,网上很多对同步、异步io模型比较的文章实际都是在说阻塞和非阻塞的事。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
2 [报告]
发表于 2013-01-16 12:58 |只看该作者
无锁 并且 高效.

论坛徽章:
0
3 [报告]
发表于 2013-01-16 13:26 |只看该作者
回复 2# linux_c_py_php

同步io亦可以无锁
   

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
4 [报告]
发表于 2013-01-16 16:47 |只看该作者
业务逻辑可以无锁?

xxxxxxxp 发表于 2013-01-16 13:26
回复 2# linux_c_py_php

同步io亦可以无锁

论坛徽章:
0
5 [报告]
发表于 2013-01-16 17:50 |只看该作者
回复 4# linux_c_py_php


    为什么不可以呢 检索线程又不一定需要独占的访问资源

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
6 [报告]
发表于 2013-01-16 17:58 |只看该作者
争辩个毛, 我就说那么个意思.

多线程基本都会用到或多或少的锁, 起码reactor和lf架构都需要锁.

xxxxxxxp 发表于 2013-01-16 17:50
回复 4# linux_c_py_php

论坛徽章:
0
7 [报告]
发表于 2013-01-16 18:04 |只看该作者
回复 6# linux_c_py_php

1.没和你争辩,只想解决问题
2.这个问题源于一些实际场景,而这些场景的服务器处理线程都没有锁访问,而且目前我们的系统中,没有使用任何锁。

论坛徽章:
4
水瓶座
日期:2013-09-06 12:27:30摩羯座
日期:2013-09-28 14:07:46处女座
日期:2013-10-24 14:25:01酉鸡
日期:2014-04-07 11:54:15
8 [报告]
发表于 2013-01-17 17:16 |只看该作者
队列不需要锁?

没用到条件变量?

死循环sleep流?

论坛徽章:
0
9 [报告]
发表于 2013-01-17 17:25 |只看该作者
回复 8# linux_c_py_php


    共享数据可以通过一写多读规避锁的使用

论坛徽章:
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
10 [报告]
发表于 2015-02-27 09:57 |只看该作者
xxxxxxxp 发表于 2013-01-16 12:53
在考虑服务器通讯模型的问题,究竟何种情况下异步io模型相对同步io模型有较大的优势?原因是什么?是同步io ...

这事跟锁没多大关系。单纯的aio并无多大意义,与epoll结合还差不多。可以通过eventfd与epoll结合起来。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP