把书读薄(Netty in Action 第四章)
Channel有什么特征?
- channel是传输API的核心,每一个都会被分配一个ChannelPipeline和ChannelConfig,ChannelConfig包含了Channel的所有配置,并且支持热更新
- 每个channel都是独一无二的,channel之间的顺序通过Comparable来实现比较
- channel的实现是线程安全的
Netty支持的传输类型有哪些?
- NIO:基于java api的selector机制实现。 大致原理是:当channel状态发生变化的时得到通知,执行状态变化相应的任务,响应结束后,选择器重置,再次重复这个过程
- Epoll:只能在linux系统中使用,高负载情况下,性能优于JDK的NIO。 大致原理是:I/O多路复用【通过一个文件符管理多个文件描述符(针对epoll可以看做无限制)】,当一个文件描述符可读或者可写的时候,收到通知,立马执行【边沿触发】
- OIO(旧的阻塞IO):基于java.net的阻塞IO。 大致原理是:单线程监听一个socket,任何I/O操作在任意的时间节点上都有可能被阻塞
- Local:同一个JVM上运行的客户端和服务端之间的通信
- Embedded:使用channel,但不需要真正意义上的网络传输,一般用于测试