I/O内存与外部设备之间拷贝数据的过程。
操作系统以进程为单位,分配资源
分配的资源:内核空间+用户空间
比如写个程序读网卡数据:
1、应用通过内核API去读网卡中的数据;
2、先把数据读到该应用的内核空间;
3、然后再放入该应用的用户空间中
常见io模型:同步阻塞、同步非阻塞、I/O多路复用、异步
服务为每个请求分配一个线程进行处理。
请求进 tomcat 我们的程序从tomcat中拿数据。
tomcat怎么和客户端建立连接,怎么读的数据,读到数据之后怎么处理,我们之前不关心(tomcat帮我们做完了),这次关注这块。
优化思路:如果一个线程能够对接100个客户端,那么我搞200个线程,并发量就上来了。
引出-IO的多路复用/非阻塞
三大核心组件:Buffer缓冲区、Channel通道、Selector多路复用器
本质是数组(有很多类型,通常是字节数组ByteBuffer)
NIO的ServerSocketChannel和SocketChannel
1、服务端要有ServerSocketChannel,用于接收客户端连接(accept方法);
2、接收到后,会在服务端创建SocketChannel和该客户端对应;
3、后续收发消息通过2个SocketChannel
流程:
1、注册-ServerSocketChannel和SocketChannel注册到Selector中
2、轮询-Selector轮询拿到一个集合(包括所有Channel的信息-是否处于就绪状态)
3、一个Selector线程去处理一个/多个处于就绪状态客户端的工作