免费注册 查看新帖 |

Chinaunix

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

[C++] libaio是glibc提供的还是kernel提供的? [复制链接]

论坛徽章:
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
11 [报告]
发表于 2017-02-08 17:02 |只看该作者
本帖最后由 yulihua49 于 2017-02-08 17:04 编辑
xinglp 发表于 2017-02-08 12:04
这个aio自己不能等待一堆io么,就像epoll那样另外这个内核aio现在支持套接字了么

可以,可是你怎样组织一堆IO呢?
作为服务器,客户端的请求是随机的,你怎么把一堆客户端的请求一起处理又不让他们互相等待。

论坛徽章:
2
2015年迎新春徽章
日期:2015-03-04 10:16:532015元宵节徽章
日期:2015-03-06 15:53:22
12 [报告]
发表于 2017-02-08 19:37 |只看该作者
windoze 发表于 2017-02-06 22:50
目前应该都是kernel aio了,除非你还在用2.4

你的意思是? 现在Libaio和glibc的aio都已经是kernel aio了,glibc也不再是调用posix aio了?

论坛徽章:
44
15-16赛季CBA联赛之浙江
日期:2021-10-11 02:03:59程序设计版块每日发帖之星
日期:2016-07-02 06:20:0015-16赛季CBA联赛之新疆
日期:2016-04-25 10:55:452016科比退役纪念章
日期:2016-04-23 00:51:2315-16赛季CBA联赛之山东
日期:2016-04-17 12:00:2815-16赛季CBA联赛之福建
日期:2016-04-12 15:21:2915-16赛季CBA联赛之辽宁
日期:2016-03-24 21:38:2715-16赛季CBA联赛之福建
日期:2016-03-18 12:13:4015-16赛季CBA联赛之佛山
日期:2016-02-05 00:55:2015-16赛季CBA联赛之佛山
日期:2016-02-04 21:11:3615-16赛季CBA联赛之天津
日期:2016-11-02 00:33:1215-16赛季CBA联赛之浙江
日期:2017-01-13 01:31:49
13 [报告]
发表于 2017-02-08 22:02 |只看该作者
回复 12# cdsfiui

glibc的aio_XXX还是以前那个吊样,libaio里面的是io_XXX,这个是新的kernel AIO,但是在2.4版本下不能用,必须要2.6或者更新的kernel。

论坛徽章:
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
14 [报告]
发表于 2017-02-08 22:21 |只看该作者
windoze 发表于 2017-02-08 22:02
回复 12# cdsfiui

glibc的aio_XXX还是以前那个吊样,libaio里面的是io_XXX,这个是新的kernel AIO,但 ...
  1. /*******************************************
  2. * 需要linux 2.6.22 以上版本
  3. * 和libaio 3.107以上版本
  4. * 如果不具备这个条件,在makefile里用SIO_fd.o
  5. * 取代本模块
  6. *******************************************/

  7. #include <unistd.h>
  8. #include <sys/stat.h>
  9. #include <fcntl.h>
  10. #include <sys/eventfd.h>
  11. #include <libaio.h>

  12. #include <scsrv.h>

  13. static int AIO_oper(int fd,char *buff,size_t iosize,int flg)
  14. {
  15. io_context_t myctx;
  16. int rc,num;
  17. uint64_t finished_aio;
  18. struct iocb _iocb,*io=&_iocb;
  19. struct io_event event;
  20. int        efd = eventfd(0, 0);
  21. T_YIELD yield=get_yield();

  22.         if (efd == -1) {   
  23.                 return flg?write(fd,buff,iosize):read(fd,buff,iosize);
  24.         }   

  25.         memset(&myctx,0,sizeof(myctx));
  26.         io_set_eventfd(io,efd);
  27.         io_queue_init(1, &myctx);
  28.         if(flg) io_prep_pread(io, fd, buff, iosize, 0);
  29.         else        io_prep_pwrite(io, fd, buff, iosize, 0);
  30.         rc = io_submit(myctx, 1, &io);
  31.         if(rc<0) {
  32.                 close(efd);
  33.                 io_destroy(myctx);
  34.                 return flg?write(fd,buff,iosize):read(fd,buff,iosize);
  35.         }
  36.         if(yield) {
  37.                 rc = yield(efd,0,0);//efd提交给epoll,并yield and resume.
  38.                 if(rc==0) eventfd_read(efd, &finished_aio);
  39.         }
  40.         close(efd);
  41.         num = io_getevents(myctx, 1, 1, &event, NULL);
  42.         if(num>0) {
  43.                 if(event.res2==0) num=event.res;
  44.                 else num=-1;
  45.         }
  46.         io_destroy(myctx);
  47.         return num;
  48. }

  49. int AIO_read(int fd,char *buff,size_t iosize)
  50. {
  51.         return AIO_oper(fd,buff,iosize,0);
  52. }

  53. int AIO_write(int fd,char *buff,size_t iosize)
  54. {
  55.         return AIO_oper(fd,buff,iosize,1);
  56. }
复制代码


论坛徽章:
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
15 [报告]
发表于 2017-02-09 11:03 |只看该作者
本帖最后由 yulihua49 于 2017-02-09 11:06 编辑

看31行,与eventfd结合,然后,在yield时,提交epoll。
还是一个原则,能异步就异步,不能异步就同步,反正事情是不能耽误的。

论坛徽章:
5
2015年辞旧岁徽章
日期:2015-03-03 16:54:152015年迎新春徽章
日期:2015-03-04 09:53:172015亚冠之水原三星
日期:2015-06-02 16:34:202015年亚冠纪念徽章
日期:2015-10-19 18:13:37程序设计版块每日发帖之星
日期:2015-11-08 06:20:00
16 [报告]
发表于 2017-02-09 11:13 |只看该作者
yulihua49 发表于 2017-02-08 17:02
可以,可是你怎样组织一堆IO呢?
作为服务器,客户端的请求是随机的,你怎么把一堆客户端的请求一起处理 ...

我的意思是这个内核的aio没有epoll或者kqueue那样的等待接口么

论坛徽章:
2
综合交流区版块每日发帖之星
日期:2016-07-06 06:20:00综合交流区版块每日发帖之星
日期:2016-08-16 06:20:00
17 [报告]
发表于 2017-02-09 12:00 |只看该作者
楼主加油,我们都看好你哦

论坛徽章:
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
18 [报告]
发表于 2017-02-09 12:32 |只看该作者
xinglp 发表于 2017-02-09 11:13
我的意思是这个内核的aio没有epoll或者kqueue那样的等待接口么

没有。必须是libaio,107以上版本。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

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

清除 Cookies - ChinaUnix - Archiver - WAP - TOP