BIO与NIO区别
IO
網(wǎng)絡(luò)IO、本地IO
網(wǎng)絡(luò)間的數(shù)據(jù)傳輸,稱(chēng)為網(wǎng)絡(luò)IO
本地磁盤(pán)間的數(shù)據(jù)傳輸,稱(chēng)為本地IO
BIO
Blocking IO
阻塞IO
實(shí)現(xiàn)原理
服務(wù)器,當(dāng)每一個(gè)請(qǐng)求進(jìn)來(lái)
要接收傳來(lái)的數(shù)據(jù),都會(huì)開(kāi)啟一個(gè)Socket
開(kāi)啟一個(gè)線程,來(lái)處理數(shù)據(jù)
讀取Socket傳遞的數(shù)據(jù)
獲取到InputStream,讀取數(shù)據(jù)
進(jìn)行業(yè)務(wù)邏輯操作,操作完成之后
返回結(jié)果
服務(wù)器會(huì)收到很多的請(qǐng)求,同時(shí)在服務(wù)器操作
在業(yè)務(wù)邏輯沒(méi)有完成之前,線程都無(wú)法得到釋放
此時(shí),服務(wù)器無(wú)法處理大量的請(qǐng)求
因?yàn)?#xff0c;有大量的線程處于阻塞狀態(tài)
等待業(yè)務(wù)邏輯的處理完成
NIO
Non-Blocking IO
非阻塞IO
Channel,通道
Buffer,進(jìn)行數(shù)據(jù)傳輸
Selector,選擇器,也稱(chēng)為多路復(fù)用器
實(shí)現(xiàn)原理
每一個(gè)請(qǐng)求過(guò)來(lái),都會(huì)創(chuàng)建一個(gè)通道
一個(gè)selector,可以注冊(cè)很多的channel
通過(guò),一個(gè)Selector監(jiān)聽(tīng)多個(gè)通道的方式
當(dāng)某一個(gè)通道的任何一個(gè)狀態(tài),準(zhǔn)備就緒
就會(huì)額外的開(kāi)啟一個(gè)線程,進(jìn)行執(zhí)行
多路復(fù)用模型
通道狀態(tài)
或者稱(chēng)為,通道的事件
Connect,連接成功準(zhǔn)備就緒
Accept,接收數(shù)據(jù)準(zhǔn)備就緒
Read,讀取數(shù)據(jù)準(zhǔn)備就緒
Write,寫(xiě)入數(shù)據(jù)準(zhǔn)備就緒
總結(jié)
- 上一篇: Dubbo整合hystrix
- 下一篇: Netty通信原理