selector的理解
2024-10-13 11:40:24
对于nio这块最近几年一直就有关注,知道非阻塞,线程池,缓冲池,io的模式select,poll,epoll,甚至epoll中的et,lt.
但是最近才有时间实际看了看netty的源码,才发现原来selector可以启用这么多,在我的印象中觉得一个服务其实一个selector就够用了,并且本身对于selector的理解也不是很深,今天就大说说自己的认识吧.
jvm把操作系统的很多特性都封装了起来,理解起来就比较困难,selector我的理解就是一个句柄,更像是一颗树,应用层把要做的事情绑定到这个树上面,对应的事情发生变化时,操作系统的底层会改变状态,然后通过java的select的方法不断的循环,就可以获取发生变化的连接.其实这块可以不限于网络方面,libevent的管道模型也是通过selector进行通知的.
这样比如在在网络绑定完地址后,就可以把当前的serversocket绑定到selector上面,当有新的连接过来,会改变serversocket的状态,select就可以获取出连接的socket,然后把socket就要读数据,就把socket在绑定到selector上面并且对这个网络的读感兴趣.写也类似,这样就完成了网络的消息通信.
在netty中,分为了boss和worker(我看的版本比较低3.多的)boss只会绑定有连接的selecotr,而把数据的读写都绑定到别的selector上面,这样可以充分发挥多核的优势.每个boss或worker线程都会有自己的selector,并且对linux的epollcpu 利用问题做了处理.
最新文章
- Mybatis框架 的快速入门
- Apache开发模块
- leetcode 136. Single Number ----- java
- 菜鸟学sql,Oracle数据库结构比较
- 5059 一起去打CS
- sql 锁相关(转)
- HotelIInventory项目小结
- windows phone 7 通过麦克风录音,并且播放
- 踩坑实录 Android studio中关于 No cached version of **** available for of处理办法
- 用阿里云的免费 SSL 证书让网站从 HTTP 换成 HTTPS
- AndFix
- awk 循环语句例子
- 为什么要使用“var me=this”这样的写法
- docker 1 为什么要使用docker
- MySql cmd下的学习笔记 —— 有关select的操作(order by,limit)
- 查看文件内容 cat , tac
- 【iCore4 双核心板_ARM】例程十七:USB_MSC实验——读/写U盘(大容量存储器)
- QT中文乱码与国际化支持
- Vertica示例数据库安装
- java的代理(编程思想)