【博学谷学习记录】超强总结,用心分享|架构师-前置知识-Netty网络编程基础

一、I/O介绍

I/O内存与外部设备之间拷贝数据的过程。

操作系统以进程为单位,分配资源
分配的资源:内核空间+用户空间
比如写个程序读网卡数据:
1、应用通过内核API去读网卡中的数据;
2、先把数据读到该应用的内核空间;
3、然后再放入该应用的用户空间中

二、常见I/O模型

常见io模型:同步阻塞、同步非阻塞、I/O多路复用、异步

2.1 BIO模型

服务为每个请求分配一个线程进行处理。

请求进 tomcat 我们的程序从tomcat中拿数据。
tomcat怎么和客户端建立连接,怎么读的数据,读到数据之后怎么处理,我们之前不关心(tomcat帮我们做完了),这次关注这块。
优化思路:如果一个线程能够对接100个客户端,那么我搞200个线程,并发量就上来了。
引出-IO的多路复用/非阻塞

2.1 NIO模型

三大核心组件:Buffer缓冲区、Channel通道、Selector多路复用器
在这里插入图片描述

2.11 Buffer缓冲区

本质是数组(有很多类型,通常是字节数组ByteBuffer)

2.12 Channel通道:双向-全双工-可读可写

NIO的ServerSocketChannel和SocketChannel
1、服务端要有ServerSocketChannel,用于接收客户端连接(accept方法);
2、接收到后,会在服务端创建SocketChannel和该客户端对应;
3、后续收发消息通过2个SocketChannel

2.13 Selecot 多路复用器/选择器

流程:
1、注册-ServerSocketChannel和SocketChannel注册到Selector中
2、轮询-Selector轮询拿到一个集合(包括所有Channel的信息-是否处于就绪状态)
3、一个Selector线程去处理一个/多个处于就绪状态客户端的工作

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值