Selector介绍

基本介绍

  1. Java的NIO,用非阻塞的IO方式。可以用一个线程,处理多个客户端连接,就会使用Selector(选择器)
  2. .Selector能够检测多个注册的通道上是否有事件发生(注意:多个Channel以事件的方式可以注册在同一个Selector),如果有事件发生,便获取事件人后针对每个事件进行相应的处理,这样就可以只用一个单线程去管理多个通道,也就是管理多个连接和请求。
  3. 只有在连接/通道真正发生读写事件时,才会进行读写,就大大的减少了系统开销,并且不比为每个连接都创建一个线程,不用去维护多个线
  4. 避免了多线程之间的上下文切换导致的开销

Selector示意图和特点说明

在这里插入图片描述

  1. Netty 的 IO 线程 NioEventLoop 聚合了 Selector(选择器,也叫多路复用器),可以同时并发处理成百上千个客户端连接。
  2. 当线程从某客户端 Socket 通道进行读写数据时,若没有数据可用时,该线程可以进行其他任务。
  3. 线程通常将非阻塞 IO 的空闲时间用于在其他通道上执行 IO 操作,所以单独的线程可以管理多个输入和输出通道。
  4. 由于读写操作都是非阻塞的,这就可以充分提升 IO 线程的运行效率,避免由于频繁 I/O 阻塞导致的线程挂起。
  5. 一个 I/O 线程可以并发处理 N 个客户端连接和读写操作,这从根本上解决了传统同步阻塞 I/O 一连接一线程模型,架构的性能、弹性伸缩能力和可靠性都得到了极大的提升。
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
Selector是Java NIO中的一个关键类,用于实现非阻塞I/O操作。通过Selector,可以同时监视多个Channel的状态,从而实现单线程处理多个通道的能力。 Selector的原理是通过底层操作系统的IO多路复用机制实现的。在Linux系统中,Java使用的是EPoll机制。当程序调用Selector的select()方法时,Selector会向操作系统注册对应的事件,然后将当前线程阻塞。当有事件发生时,操作系统会通知SelectorSelector会将对应的Channel标记为就绪状态,使得程序可以进行读写操作。 在Java NIO中,Selector与Channel是一一对应的关系。当一个Channel注册到Selector上时,Selector会为该Channel创建一个SelectionKey,通过SelectionKey可以获取Channel的状态和事件。Selector可以使用select()、select(long timeout)、selectNow()进行阻塞和非阻塞的选择操作。而Selector使用wakeup()方法可以唤醒被阻塞的select()操作。 总结起来,Selector通过底层操作系统的IO多路复用机制,实现了多个Channel的监视和处理,提供了高效的非阻塞I/O操作能力。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [Selector 实现原理](https://blog.csdn.net/weixin_37570817/article/details/77980162)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] - *2* [netty入门(五)Selector介绍和原理](https://blog.csdn.net/zhufei463738313/article/details/129078112)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

程序员劝退师-TAO

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值