计网 - 一台内存在 8G 左右的服务器,可以同时维护多少个连接?
生活随笔
收集整理的這篇文章主要介紹了
计网 - 一台内存在 8G 左右的服务器,可以同时维护多少个连接?
小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
文章目錄
- Question
Question
一臺內存在 8G 左右的服務器,可以同時維護多少個連接?
分析:
連接是內存中的狀態對象,從理論上分析,連接本身不太占用內存。不同語言連接對象大小不等,但是通常很小。下面提供一段 Java 程序
public class Server {public static void main(String[] argv) throws IOException {var serverSocket = new ServerSocket();var addr = new InetSocketAddress(3001);serverSocket.bind(addr);var list = new LinkedList<>();while(true) {var client = serverSocket.accept();list.add(client);System.out.println(list.size());}}}public class Client {public static void main(String[] argv) throws IOException, InterruptedException {var clients = new LinkedList<>();for(int i = 0; i < 1000000; i++) {var client = new Socket("127.0.0.1", 3001);clients.add(client);}Thread.sleep(10000000);}}通過運行上面這段程序,你可以觀察到以下這幾個現象:
創建 100W 連接速度不是很快,這說明 TCP 連接創建有成本(3 次握手,都是網絡 IO);
用jps找到對應的進程的id,在用sudo cat /proc/{進程ID}/status | grep VmHWM可以看到實際的內存占用。按照這種增長趨勢,8G 內存空間可以輕輕松松存放 100W 個連接。
但是如果單機建立太多的連接,會報一個Cannot assign requested address的異常,這是因為客戶端連接服務端時,操作系統要為每個客戶端分配一個端口,上面的程序很快會把端口號用盡。
所以,我們可以得出一個結論:核心的問題是,通信需要緩沖區,通信需要 I/O。這是因為通信占用資源,連接本身占用資源少。
《新程序員》:云原生和全面數字化實踐50位技術專家共同創作,文字、視頻、音頻交互閱讀
總結
以上是生活随笔為你收集整理的计网 - 一台内存在 8G 左右的服务器,可以同时维护多少个连接?的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: 计网 - TCP 的封包格式:TCP 为
- 下一篇: 计网 - IPv4 协议:路由和寻址的区