探索Java通信面試的奧秘:揭秘IO模型、選擇器和網路協議,瞭解面試中的必備知識點!

来源:https://www.cnblogs.com/guoxiaoyu/archive/2023/07/27/17583809.html
-Advertisement-
Play Games

通過深入探索Java通信面試的奧秘,我們將揭秘Java中的三種I/O模型(BIO、NIO和AIO)、選擇器(select、poll和epoll)以及網路協議(如HTTP和HTTPS),幫助您瞭解在面試中必備的知識點。這些知識點對於網路編程和系統安全方面的求職者來說至關重要,掌握它們將為您的職業發展打... ...


瞭解常見的TCP/UDP

TCP(Transmission Control Protocol)是一種面向連接的可靠的傳輸協議。類似於打電話,它通過建立一個連接和保證數據的可靠傳輸來提高通信的可靠性。然而,由於要確保數據的可靠性,TCP協議會增加網路負擔,效率相對較低。

UDP(User Datagram Protocol)是一種無連接、不可靠的傳輸協議。類似於廣播,UDP協議可以實現一對多的通信,且由於沒有連接的建立和數據的確認,所以傳輸效率相對較高。然而,由於缺乏連接和確認機制,UDP的可靠性較差。

在瞭解TCP和UDP之後,常見的面試題包括TCP的三次握手和四次揮手。為什麼要採用三次握手而不是兩次握手呢?這是因為網路傳輸本身具有不穩定性,例如網路超時和網路阻塞等問題。如果只進行兩次握手,當服務端返回第二次握手給客戶端後,無法確定客戶端是否成功建立連接。因此,必須進行第三次握手,以確保客戶端接收到了連接請求。否則,如果客戶端由於網路原因導致丟失了此次連接請求,伺服器將一直等待該連接的空閑超時才會關閉請求,這將嚴重消耗伺服器資源。

四次揮手也是類似於三次握手的原因。由於網路傳輸的不穩定性,斷開連接時需要確保雙方都收到斷開請求。在四次揮手中,首先客戶端發送斷開連接請求,然後服務端發送確認收到請求的消息,接著服務端發送斷開連接請求,最後客戶端發送確認收到請求的消息,完成連接的斷開。這樣可以確保雙方都能正確處理斷開連接的操作。

瞭解BIO、NIO、AIO

BIO是最簡單的一種I/O模型,它採用同步阻塞方式進行通信。每個客戶端連接都需要獨立的線程進行處理,當有大量的併發請求時,線程數量會急劇增加,導致資源消耗增加,性能下降。

image

NIO是相對複雜的一種I/O模型,它使用了Channel、Selector和Buffer來實現非阻塞的通信。通過Selector的多路復用機制,可以使用一個線程處理多個客戶端連接,從而提高併發能力。但是,NIO適合處理短請求,如果長時間占用I/O,可能會導致伺服器資源耗盡。

image

以下是使用NIO實現一個簡單的伺服器示例:

import java.io.IOException;
import java.net.InetSocketAddress;
import java.nio.ByteBuffer;
import java.nio.channels.ServerSocketChannel;
import java.nio.channels.SelectionKey;
import java.nio.channels.Selector;
import java.nio.channels.SocketChannel;
import java.util.Iterator;

public class NioServerExample {
    public static void main(String[] args) throws IOException {
        // 創建ServerSocketChannel,並綁定埠
        ServerSocketChannel serverSocketChannel = ServerSocketChannel.open();
        serverSocketChannel.socket().bind(new InetSocketAddress(8080));
        serverSocketChannel.configureBlocking(false);

        // 創建Selector,並將ServerSocketChannel註冊到Selector上
        Selector selector = Selector.open();
        serverSocketChannel.register(selector, SelectionKey.OP_ACCEPT);

        while (true) {
            // 監聽事件
            selector.select();

            // 處理事件
            Iterator<SelectionKey> keyIterator = selector.selectedKeys().iterator();
            while (keyIterator.hasNext()) {
                SelectionKey key = keyIterator.next();
                keyIterator.remove();

                if (key.isAcceptable()) {
                    // 接受客戶端連接
                    ServerSocketChannel serverChannel = (ServerSocketChannel) key.channel();
                    SocketChannel socketChannel = serverChannel.accept();
                    socketChannel.configureBlocking(false);
                    socketChannel.register(selector, SelectionKey.OP_READ);
                } else if (key.isReadable()) {
                    // 讀取客戶端數據
                    SocketChannel socketChannel = (SocketChannel) key.channel();
                    ByteBuffer buffer = ByteBuffer.allocate(1024);
                    int bytesRead = socketChannel.read(buffer);
                    if (bytesRead == -1) {
                        // 客戶端關閉連接
                        socketChannel.close();
                    } else {
                        buffer.flip();
                        byte[] data = new byte[buffer.remaining()];
                        buffer.get(data);
                        String message = new String(data);
                        System.out.println("Received message: " + message);

                        // 響應客戶端
                        ByteBuffer responseBuffer = ByteBuffer.wrap("Hello, client!".getBytes());
                        socketChannel.write(responseBuffer);
                    }
                }
            }
        }
    }
}

AIO相對於NIO來說簡單一些,但是由於底層需要操作系統的支持,所以應用範圍相對較小。AIO是非同步非阻塞的I/O模型,在NIO的基礎上,通過另外的線程來處理業務的返回值,從而實現非同步操作。

image


JAVA NIO的核心組件

JAVA NIO的核心組件包括緩衝區(buffer)、通道(channel)和選擇器(selector)。

  • 緩衝區用於存儲客戶端與伺服器端交互的數據信息,
  • 而通道類似於流,每個客戶端都會有一個獨立的通道。
  • 選擇器是多路復用的關鍵,它能夠找出具有事件的通道,並將其交給伺服器線程進行處理。

通過這些核心組件,JAVA NIO模型實現了高效的非阻塞I/O操作,提升了伺服器的併發處理能力。

image

select、poll和epoll的比較與應用

select、poll和epoll是Linux系統中的三種I/O多路復用機制。它們的目的是為了實現高效的事件驅動編程,以便在多個I/O操作中選擇可讀、可寫或異常事件。

文件描述符是維護進程打開文件的記錄表。每個打開的文件都會被分配一個唯一的文件描述符。

  • select是最古老的機制之一,它可以同時監視多個文件描述符的狀態變化。但是,select有一些缺點,例如每次調用時都需要將文件描述符集合從用戶空間拷貝到內核空間,效率較低。此外,select支持的文件描述符數量有限。
  • poll是select的改進版本,它通過一個pollfd結構體數組來傳遞文件描述符信息給內核,避免了select中每次調用都需要拷貝的問題。poll也支持更多的文件描述符,但是隨著文件描述符數量的增加,性能會有所下降。
  • epoll是在Linux 2.6內核中引入的新機制,它通過epoll_ctl和epoll_wait函數來註冊和等待事件。epoll使用一個事件數組來存儲被監視的文件描述符和事件狀態,只需要在註冊時將文件描述符添加到事件數組中,而不需要像select和poll一樣在每次調用時傳遞整個文件描述符集合。這使得epoll在大規模併發情況下具有更高的性能。

HTTP vs HTTPS:理解兩者之間的區別與安全性

安全性:

  • HTTP是明文協議,數據在傳輸過程中不加密,容易被第三方截獲和竊聽。
  • HTTPS通過使用SSL(Secure Sockets Layer)或TLS(Transport Layer Security)協議對數據進行加密和身份驗證,提供更高的安全性。

埠號:

  • HTTP預設使用埠號80進行通信
  • HTTPS預設使用埠號443進行通信

證書:

  • HTTPS使用數字證書來驗證伺服器的身份。證書由可信的第三方機構頒發,用於確保通信雙方的身份和數據的完整性。
  • HTTP不需要使用證書,無法驗證伺服器的身份。

HTTPS協議增加了伺服器和客戶端之間的計算和通信負擔,使得伺服器在處理大量請求時更容易受到壓力。雖然HTTPS可以提供一定程度的安全保護,但也會增加伺服器的負擔,使得伺服器更容易受到DDoS攻擊。

總結

通過深入探索Java通信面試的奧秘,我們將揭秘Java中的三種I/O模型(BIO、NIO和AIO)、選擇器(select、poll和epoll)以及網路協議(如HTTP和HTTPS),幫助您瞭解在面試中必備的知識點。這些知識點對於網路編程和系統安全方面的求職者來說至關重要,掌握它們將為您的職業發展打下堅實的基礎!


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • ## 開篇介紹 Java 8 中新增的特性旨在幫助程式員寫出更好的代碼,其中對核心類庫的改進是很關鍵的一部分,也是本章的主要內容。對核心類庫的改進主要包括集合類的 API 和新引入的流(Stream),流使程式員得以站在更高的抽象層次上對集合進行操作。下麵將介紹stream流的用法。 ## 1.初始 ...
  • # 同步電路與非同步電路 - ## 同步電路 - 電路中所有觸發器均連接同一個時鐘脈衝源,觸發器的狀態變化均與時鐘脈衝信號同步; - 電路中所有時鐘同源同相; - 同相位時鐘:始終頻率不同,但是時鐘邊沿對齊; - ![](https://img2023.cnblogs.com/blog/1964011 ...
  • 上節討論瞭如何保障數據中台的數據質量,讓數據“準”。除了“快”和“準”,數據中台還離不開“省”。隨數據規模越來越大,成本越來越高,如不合理控製成本,還沒等你挖掘出數據應用價值,企業利潤就被消耗完。 能否做到精細化成本管理,關乎數據中台項目成敗。 某電商業務數據建設資源增長趨勢(CU= 1vcpu + ...
  • # 事務 - **基本介紹** 1. JDBC 程式中當一個Connection對象創建時,預設情況下是自動提交事務:每次執行一個 SQL 語句時,如果執行成功,就會向資料庫自動提交,而不能回滾。 2. JDBC程式中為了多個SQL語句作為一個整體執行,需要==使用事務==。 3. 調用 Conne ...
  • ## 教程簡介 Excel Power View 是一種數據可視化技術,用於創建互動式圖表、圖形、地圖和其他視覺效果,以便直觀呈現數據。 Excel Power View中,可以快速創建各種可視化效果,從表格和矩陣到餅圖、條形圖和氣泡圖,以及多個圖表的集合。要創建各種可視化效果,請首先從表格開始著手 ...
  • 經常開發表格,是不是已經被手寫Ant-Design Table的Columns整煩了?尤其是ToB項目,表格經常動不動就幾十列。每次照著後端給的介面文檔一個個配置,太頭疼了,主要是有時還會粘錯就尷尬了。那有沒有辦法能自動生成columns配置呢? ...
  • 通過本文可以瞭解FutureTask任務執行的方式以及Future.get已阻塞的方式獲取線程執行的結果原理,並且從代碼中可以瞭解FutureTask的任務執行狀態以及狀態的變化過程。 ...
  • 環境是PhpStorm+Xdebug+WAMP 在實際調試的過程中 碰到了調試還沒走完就自動結束的情況 很尷尬 查閱了相關文檔資料 找到瞭解決方法 首先在php.ini中進行修改 我的配置文件地址在 ``` "D:\phpstudy_pro\Extensions\php\php7.3.4nts\ph ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...