udp之關於linux udp收發包緩衝區大小
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相關的知識
socket之send與傳送緩衝區大小的關係
自己做了個測試,伺服器只起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:網路UDP之socket套接字
socket簡介: socket(簡稱 套接字) 是程序間通訊的一種方式,它與其他程序間通訊的一個主要不同是: 它能實現不同主機間的程序間通訊,我們網路上各種各樣的服務大多都是基於 Socket 來完成通訊的 1. 不同電腦上的程序之間如何通訊:首要解決的問題是如何
Unity3d之Socket UDP協議
(一)Socket(套接字)UDP協議的特點 1、是基於無連線的協議,沒有生成連線的延遲所以速度比TCP快; 2、支援一對一和一對多連線,可以使用廣播的方式多地址傳送; 3、與Tcp的報頭比是8:20,所以UDP消耗的網路頻寬少; 4、傳輸的資料有訊息邊界,Tcp沒有;