redis源码阅读之ae_kqueue

栏目: 数据库 · 发布时间: 6年前

内容简介:kqueue是FreeBSD当中提供的io多路复用机制,由于上一篇在介绍epoll()的时候被告知有敏感词,不让发,那kqueue()的具体介绍也就只能往后延一下了,这里着重介绍redis是如何包装的其一般的api调用如下:关键api如下:

kqueue是FreeBSD当中提供的io多路复用机制,由于上一篇在介绍epoll()的时候被告知有敏感词,不让发,那kqueue()的具体介绍也就只能往后延一下了,这里着重介绍 redis 是如何包装的

点击( 此处 )折叠或打开

  1. typedef struct aeApiState {
  2.      int kqfd ;
  3.     struct kevent * events ;
  4. } aeApiState ;

其一般的api调用如下:

点击( 此处 )折叠或打开

  1. static int aeApiCreate ( aeEventLoop * eventLoop ) {
  2.     aeApiState * state = zmalloc ( sizeof ( aeApiState ) ) ;
  3.      if ( ! state ) return - 1 ;
  4.     state - > events = zmalloc ( sizeof ( struct kevent ) * eventLoop - > setsize ) ;
  5.      if ( ! state - > events ) {
  6.         zfree ( state ) ;
  7.         return - 1 ;
  8.      }
  9.     state - > kqfd = kqueue ( ) ;
  10.      if ( state - > kqfd = = - 1 ) {
  11.         zfree ( state - > events ) ;
  12.         zfree ( state ) ;
  13.         return - 1 ;
  14.      }
  15.     eventLoop - > apidata = state ;
  16.     return 0 ;
  17. }
  18. static int aeApiResize ( aeEventLoop * eventLoop , int setsize ) {
  19.     aeApiState * state = eventLoop - > apidata ;
  20.     state - > events = zrealloc ( state - > events , sizeof ( struct kevent ) * setsize ) ;
  21.     return 0 ;
  22. }
  23. static void aeApiFree ( aeEventLoop * eventLoop ) {
  24.     aeApiState * state = eventLoop - > apidata ;
  25.     close ( state - > kqfd ) ;
  26.     zfree ( state - > events ) ;
  27.     zfree ( state ) ;
  28. }
  29. static int aeApiAddEvent ( aeEventLoop * eventLoop , int fd , int mask ) {
  30.     aeApiState * state = eventLoop - > apidata ;
  31.     struct kevent ke ;
  32.      if ( mask & AE_READABLE ) {
  33.         EV_SET ( & ke , fd , EVFILT_READ , EV_ADD , 0 , 0 , NULL ) ;
  34.          if ( kevent ( state - > kqfd , & ke , 1 , NULL , 0 , NULL ) = = - 1 ) return - 1 ;
  35.      }
  36.      if ( mask & AE_WRITABLE ) {
  37.         EV_SET ( & ke , fd , EVFILT_WRITE , EV_ADD , 0 , 0 , NULL ) ;
  38.          if ( kevent ( state - > kqfd , & ke , 1 , NULL , 0 , NULL ) = = - 1 ) return - 1 ;
  39.      }
  40.     return 0 ;
  41. }
  42. static void aeApiDelEvent ( aeEventLoop * eventLoop , int fd , int mask ) {
  43.     aeApiState * state = eventLoop - > apidata ;
  44.     struct kevent ke ;
  45.      if ( mask & AE_READABLE ) {
  46.         EV_SET ( & ke , fd , EVFILT_READ , EV_DELETE , 0 , 0 , NULL ) ;
  47.         kevent ( state - > kqfd , & ke , 1 , NULL , 0 , NULL ) ;
  48.      }
  49.      if ( mask & AE_WRITABLE ) {
  50.         EV_SET ( & ke , fd , EVFILT_WRITE , EV_DELETE , 0 , 0 , NULL ) ;
  51.         kevent ( state - > kqfd , & ke , 1 , NULL , 0 , NULL ) ;
  52.      }
  53. }
  54. static char * aeApiName ( void ) {
  55.     return "kqueue" ;
  56. }

关键api如下:

点击( 此处 )折叠或打开

  1. static int aeApiPoll ( aeEventLoop * eventLoop , struct timeval * tvp ) {
  2.     aeApiState * state = eventLoop - > apidata ;
  3.      int retval , numevents = 0 ;
  4.      if ( tvp ! = NULL ) {
  5.         struct timespec timeout ;
  6.         timeout . tv_sec = tvp - > tv_sec ;
  7.         timeout . tv_nsec = tvp - > tv_usec * 1000 ;
  8.         retval = kevent ( state - > kqfd , NULL , 0 , state - > events , eventLoop - > setsize ,
  9.                          & timeout ) ;
  10.      } else {
  11.         retval = kevent ( state - > kqfd , NULL , 0 , state - > events , eventLoop - > setsize ,
  12.                          NULL ) ;
  13.      }
  14.      if ( retval > 0 ) {
  15.          int j ;
  16.         numevents = retval ;
  17.          for ( j = 0 ; j < numevents ; j + + ) {
  18.              int mask = 0 ;
  19.             struct kevent * e = state - > events + j ;
  20.              if ( e - > filter = = EVFILT_READ ) mask | = AE_READABLE ;
  21.              if ( e - > filter = = EVFILT_WRITE ) mask | = AE_WRITABLE ;
  22.             eventLoop - > fired [ j ] . fd = e - > ident ;
  23.             eventLoop - > fired [ j ] . mask = mask ;
  24.          }
  25.      }
  26.     return numevents ;
  27. }

还请各位看官老爷多提宝贵意见~


以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持 码农网

查看所有标签

猜你喜欢:

本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们

连线

连线

加里·沃尔夫 / 黄锫坚 / 中国铁道出版社 / 2006-7 / 29.80元

简言之,是一个人和一本杂志的传奇……   放在大环境中,是一个时代的跌宕起伏……   一直大力地向所有人推荐这本书,只是因为,故事真的很精彩,是一个伟大而疯狂的时代所造就的一个不屈不挠的斗士——路易斯·罗塞托,还有这本举世皆知的杂志——《连线》。   通过本书,中国读者会知道,新经济热潮的主角不仅是比尔·盖茨、杨致远等技术和商业能人,还有一大批新文化的传教士和吹鼓手,比如路易斯·......一起来看看 《连线》 这本书的介绍吧!

图片转BASE64编码
图片转BASE64编码

在线图片转Base64编码工具

SHA 加密
SHA 加密

SHA 加密工具

RGB CMYK 转换工具
RGB CMYK 转换工具

RGB CMYK 互转工具