在一个只读的fd上进行IO多路复用是否有助于获得比仅阻止读取更好的性能?

时间:2016-04-29 06:56:17

标签: c sockets io asyncsocket multiplexing

根据我的知识,我认为如果我只需要在一个单独的fd上执行读取操作,像select / poll这样的IO多路复用对性能没有帮助,它甚至比仅仅阻塞地读取fd会产生更多的开销。

但是linux auditd project但是在一个读取套接字上使用select。能有人解释一下它的含义吗?

审计代码也可以在1个socket / 1管道和5个信号上使用libev。如果我只关心主要的netlink套接字,那么使用阻塞读取会更好吗?

我认为可能的场景可能是监听udp接收器套接字等。

为方便起见,附加了代码块。提前谢谢!

925 static int get_reply(int fd, struct audit_reply *rep, int seq)
926 {
927         int rc, i;
928         int timeout = 30; /* tenths of seconds */
929 
930         for (i = 0; i < timeout; i++) {
931                 struct timeval t;
932                 fd_set read_mask;
933 
934                 t.tv_sec  = 0;
935                 t.tv_usec = 100000; /* .1 second */
936                 FD_ZERO(&read_mask);
937                 FD_SET(fd, &read_mask);
938                 do {
939                         rc = select(fd+1, &read_mask, NULL, NULL, &t);
940                 } while (rc < 0 && errno == EINTR);
941                 rc = audit_get_reply(fd, rep, 
942                         GET_REPLY_NONBLOCKING, 0);
943                 if (rc > 0) {
944                         /* Don't make decisions based on wrong packet */
945                         if (rep->nlh->nlmsg_seq != seq)
946                                 continue;
947 
948                         /* If its not what we are expecting, keep looping */
949                         if (rep->type == AUDIT_SIGNAL_INFO)
950                                 return 1;
951 
952                         /* If we get done or error, break out */
953                         if (rep->type == NLMSG_DONE || rep->type == NLMSG_ERROR)
954                                 break;
955                 }
956         }
957         return -1;
958 }

2 个答案:

答案 0 :(得分:1)

不,通过使用select()poll()等I / O多路复用系统来监听单个套接字上的数据,与该套接字上的连续阻塞读取相比,您的性能不会提高。 / p>

答案 1 :(得分:0)

性能可能会有所不同,具体取决于平台(在本例中为Linux),但它不应该更快。

代码使用select的主要原因似乎是它的超时能力。它允许读取超时而不实际修改套接字的超时(SO_SNDTIMEOSO_RCVTIMEO)[或者如果套接字甚至支持超时]。