zoukankan      html  css  js  c++  java
  • java面试题之select、poll和epoll的区别

     

    消息传递方式:

    select:内核需要将消息传递到用户空间,需要内核的拷贝动作;

    poll:同上;

    epoll:通过内核和用户空间共享一块内存来实现,性能较高;

     

    文件句柄剧增后带来的IO效率问题:

    select:因为每次调用都会对连接进行线性遍历,所以随着FD剧增后会造成遍历速度的“线性下降”的性能问题;

    poll:同上;

    epoll:由于epoll是根据每个FD上的callable函数来实现的,只有活跃的socket才会主动调用callback,所以在活跃socket较少的情况下,使用epoll不会对性能产生线性下降的问题,如果所有socket都很活跃的情况下,可能会有性能问题;

     

    支持一个进程所能打开的最大连接数:

    select:单个进程所能打开的最大连接数,是由FD_SETSIZE宏定义的,其大小是32个整数大小(在32位的机器上,大小是3232,64位机器上FD_SETSIZE=3264),我们可以对其进行修改,然后重新编译内核,但是性能无法保证,需要做进一步测试;

    poll:本质上与select没什么区别,但是他没有最大连接数限制,他是基于链表来存储的;

    epoll:虽然连接数有上线,但是很大,1G内存的机器上可以打开10W左右的连接;

  • 相关阅读:
    nmap 查看内网存活主机
    msf ms17_010 port:445
    nmap 检测ms17-010 port:445
    msf mysql port:3306
    msf ssh port:22
    Wireshark的两种过滤器与BPF过滤规则
    Wireshark使用记录
    过滤搜索引擎的抓取数据
    WEB容器开启、关闭OPTIONS方法
    代码泄露到Github
  • 原文地址:https://www.cnblogs.com/hujinshui/p/10450548.html
Copyright © 2011-2022 走看看