Netty中的信息传输

把书读薄(Netty in Action 第四章)

Channel有什么特征?

  1. channel是传输API的核心,每一个都会被分配一个ChannelPipeline和ChannelConfig,ChannelConfig包含了Channel的所有配置,并且支持热更新 
  2. 每个channel都是独一无二的,channel之间的顺序通过Comparable来实现比较 
  3. channel的实现是线程安全的

Netty支持的传输类型有哪些?

  1. NIO:基于java api的selector机制实现。   大致原理是:当channel状态发生变化的时得到通知,执行状态变化相应的任务,响应结束后,选择器重置,再次重复这个过程


  2.  Epoll:只能在linux系统中使用,高负载情况下,性能优于JDK的NIO。     大致原理是:I/O多路复用【通过一个文件符管理多个文件描述符(针对epoll可以看做无限制)】,当一个文件描述符可读或者可写的时候,收到通知,立马执行【边沿触发】
  3. OIO(旧的阻塞IO):基于java.net的阻塞IO。    大致原理是:单线程监听一个socket,任何I/O操作在任意的时间节点上都有可能被阻塞 
  4. Local:同一个JVM上运行的客户端和服务端之间的通信 
  5. Embedded:使用channel,但不需要真正意义上的网络传输,一般用于测试

猜你喜欢

转载自blog.csdn.net/weixin_39687783/article/details/80102241
今日推荐