1. 程式人生 > >udp之關於linux udp收發包緩衝區大小

udp之關於linux udp收發包緩衝區大小

1、修訂單個socket的緩衝區大小:通過setsockopt使用SO_RCVBUF來設定接收緩衝區,該引數在設定的時候不會與rmem_max進行對比校驗,但是如果設定的大小超過rmem_max的話,則超過rmem_max的部分不會生效;
2、修訂linux系統udp緩衝區大小:通過rmem_max來設定系統中udp快取的上限,該值可通過如下方式檢視:
[email protected]:/mnt/hgfs/vm-shared/socket# cat /proc/sys/net/core/rmem_max
131071
通過如下方式進行修訂:
[email protected]:/mnt/hgfs/vm-shared/socket# vi /etc/sysctl.conf

在檔案/etc/sysctl.conf中新增如下資訊:
rmem_max=MAX
需要注意的這裡設定的rmem_max引數是整個系統的大小,不是單個socket的大小。
修訂後的大小可以通過如下命令檢視:
[email protected]:/mnt/hgfs/vm-shared/socket# sysctl -a | grep rmem_max

net.core.rmem_max = 131071

總結
要修訂linux udp收包緩衝大小,需要上述兩個地方同時修改:
1.只改第1點,緩衝區大小會受到rmem_max的限制。
  只改第2點,一個socket只會預留63個報文的接收緩衝。
2.

// 接收緩衝區
int nRecvBuf=32*1024;//設定為32K


setsockopt(s,SOL_SOCKET,SO_RCVBUF,(const char*)&nRecvBuf,sizeof(int));
//傳送緩衝區
int nSendBuf=32*1024;//設定為32K
setsockopt(s,SOL_SOCKET,SO_SNDBUF,(const char*)&nSendBuf,sizeof(int));

發包緩衝區與收包緩衝區一樣,只不過引數名稱不一樣:SO_SNDBUF、wmem_max。
通過如下命令可以檢視對應緩衝區中現有的報文數量:
[email protected]:/mnt/hgfs/vm-shared/socket# netstat -na | more


Active Internet connections (servers and established)
Proto Recv-Q Send-Q Local Address           Foreign Address         State      
tcp        0      0 0.0.0.0:111             0.0.0.0:*               LISTEN     
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN     
tcp        0      0 0.0.0.0:23              0.0.0.0:*               LISTEN     
tcp        0      0 127.0.0.1:631           0.0.0.0:*               LISTEN     
tcp        0      0 0.0.0.0:53113           0.0.0.0:*               LISTEN     
tcp        0      0 0.0.0.0:35551           0.0.0.0:*               LISTEN     
tcp        0      0 0.0.0.0:2049            0.0.0.0:*               LISTEN     
tcp        0      0 0.0.0.0:42697           0.0.0.0:*               LISTEN     
tcp        0     52 192.168.16.55:22        192.168.16.48:57258     ESTABLISHED
tcp6       0      0 :::22                   :::*                    LISTEN     
tcp6       0      0 ::1:631                 :::*                    LISTEN     
tcp6       0      0 :::445                  :::*                    LISTEN     
tcp6       0      0 :::139                  :::*                    LISTEN     
udp        0      0 0.0.0.0:58548           0.0.0.0:*                          
udp        0      0 0.0.0.0:68              0.0.0.0:*                          
udp        0      0 0.0.0.0:52684           0.0.0.0:*                          
udp        0      0 0.0.0.0:57298           0.0.0.0:*                          
udp        0      0 0.0.0.0:5353            0.0.0.0:*                          
udp        0      0 0.0.0.0:54889           0.0.0.0:*                          
udp        0      0 0.0.0.0:111             0.0.0.0:*                          
udp        0      0 0.0.0.0:2049            0.0.0.0:*                          
udp   260464      0 0.0.0.0:2435            0.0.0.0:*      
這個例子中埠號為2435的socket快取了260464/1784 = 146個報文。

相關推薦

udp關於linux udp發包緩衝區大小

1、修訂單個socket的緩衝區大小:通過setsockopt使用SO_RCVBUF來設定接收緩衝區,該引數在設定的時候不會與rmem_max進行對比校驗,但是如果設定的大小超過rmem_max的話,則超過rmem_max的部分不會生效;2、修訂linux系統udp緩衝區大

centos7更改系統udp緩衝區大小

udp對收發緩衝區的大小比較敏感:udp緩衝區的大小主要和以下幾個值有關:/proc/sys/net/core/rmem_max ——— udp緩衝區的最大值,單位位元組,下同/proc/sys/net/core/rmem_default ——— udp緩衝區的預設值,如果不

Linux網路程式設計Tcp/Udp socket檔案傳輸示例

本文所述示例程式是基於Linux平臺的socket網路程式設計,實現檔案傳輸功能。該示例是基於TCP流協議實現的socket網路檔案傳輸程式。採用C語言編寫。最終能夠實現傳輸任何格式檔案的檔案傳輸程式。 具體實現程式碼如下: /***********************

udp改變緩衝區大小

windows: 包含的標頭檔案#include <WinSock.h> int nRecvBuf=64*1024;//設定為64Ksetsockopt(listenSocket,SOL_SOCKET, SO_RCVBUF,(const char*)&n

網絡編程基於UDP協議套接字

本質 系統內存 現象 服務 自身 png 收發消息 accept color 1.UDP協議介紹(數據報協議)   UDP協議不同於TCP,通信時,它不需要事先建立雙向鏈接,並且不區分客戶端先啟動還是服務端前起,工作原理:基於udp協議傳輸的信息,協議會將數據自動加上自定義

Linux UDP

可能 bsp 修改內核 mage errno 一個 ech 服務端 bbb UDP的特點 無連接 直接發發發 基於消息的數據傳輸服務 , 因此不存在TCP的粘包問題,但是存在丟包問題 不可靠。 一般情況下UDP更加高效 UDP註意點 UDP報文可能會丟失、重復 UDP

Linux-UDP socket程式設計

伺服器     1、建立連線     socket(),分配檔案描述符,即監聽套接字     bind(),將套接字與本地IP地址和埠繫結    

網路基本概念TCP, UDP, 單播(Unicast), 多播(組播)(Multicast)

這篇文章相當低階,但相當重要! 我們周圍一切幾乎都依賴於把事情抽象成低等級,並在某一點把它具體化,在一些設計概念中,介面層十分清晰並且目標很集中,應用程式不用考慮作業系統如何工作,作業系統也不用考慮硬體如何工作,OSI模型的第4層不需要考慮第三層如何工作。所以我們只需要集中精力在某一

linux UDP併發伺服器

摘要: 本文將討論UDP的併發實現機制。給出了兩種實現方法。第一種是最為常見的,TFTP傳輸的方式。 第二種是對UDP進一步封裝,以達到併發的可能。主要是採用佇列、多執行緒的方法。後面會給出一個簡單的實現例子,以供大家參考。功能方面較為簡單,以後會慢慢完善。 現將思路整理如下,有興趣的

UDP---QT的QUdpSocket使用

一、概述:                                         &nbs

TCP、UDP三次握手四次揮手

1. http協議的簡介 HTTP,HyperText Transfer Protocol。超文字傳輸協議,是網際網路上應用最為廣泛的一種網路協議。基於TCP的協議,HTTP是一個客戶端和伺服器端請求和應答的標準 2. TCP三次握手過程 SYN是請求

Linux UDP socket 設定為的非阻塞模式與阻塞模式區別

UDP socket 設定為的非阻塞模式  ? 1 Len

UDP資料報接收過程(一)

UDP資料報的接收要分兩部分來看: 網路層接收完資料包後遞交給UDP後,UDP的處理過程。該過程UDP需要做的工作就是接收資料包並對其進行校驗,校驗成功後將其放入接收佇列中等待使用者空間程式來讀取。 使用者空間程式呼叫read()等系統呼叫讀取已經放入接收佇列

一起來玩linux udp通訊程式

         在之前的博文中, 我玩過Windows下的udp, 而linux下的udp也類似, 而且, 相比較tcp而言, 我發現我越來越喜歡udp了。話不多說, 直接上菜:         服務端程式為:#include <stdio.h> #includ

Linux UDP嚴重丟包問題的解決

本文轉自 :http://blog.csdn.net/kingmax26/article/details/5252667 測試系統在Linux上的效能發現丟包率極為嚴重,發210000條資料,丟包達110000之巨,丟包率超過50%。同等情形下Windows上測試,僅丟幾

RTSP協議TCP/UDP問題

前言 RTSP(Real-Time StreamingProtocol)實時流式協議在直播、流媒體、視訊會議等平臺用得很多,它是基於TCP/IP開發的上層協議,所以音視訊流資料可以用TCP或者UDP來傳輸。這篇文章目的主要是講述這二者的區別,如果想了解更多RTSP相關的知識

socketsend與傳送緩衝區大小的關係

自己做了個測試,伺服器只起socket在偵聽,不recv, 也不send. //ubuntu10.04 32bit #include <stdio.h> #include <sys/types.h> #include <sys/socke

linux udp組播接收問題及原理分析

現象: 在某個網路環境下,同一個udp組播源(igmpv2),同樣的收流程式碼,在windows上能收到,linux上收不到。排除網路拓撲結構、程式語言、硬體驅動等問題,我們就此問題來分析原理及解決方案。 環境: 交換機出,組播地址224.X.X.X,機器多網絡卡,eth

Python:網路UDPsocket套接字

socket簡介: socket(簡稱 套接字) 是程序間通訊的一種方式,它與其他程序間通訊的一個主要不同是: 它能實現不同主機間的程序間通訊,我們網路上各種各樣的服務大多都是基於 Socket 來完成通訊的 1. 不同電腦上的程序之間如何通訊:首要解決的問題是如何

Unity3dSocket UDP協議

(一)Socket(套接字)UDP協議的特點 1、是基於無連線的協議,沒有生成連線的延遲所以速度比TCP快; 2、支援一對一和一對多連線,可以使用廣播的方式多地址傳送; 3、與Tcp的報頭比是8:20,所以UDP消耗的網路頻寬少; 4、傳輸的資料有訊息邊界,Tcp沒有;