Tunning and observing UDP buffers
UDP buffers are controlled by 7 sysctl parameters. Individual buffer sizes are controlled by:
-
net.core.wmem_default, net.core.wmem_max
– default and max socket send buffer size in bytes. Each socket getswmem_default
send buffer size by default, and can request up towmem_max
with setsockopt optionSO_SNDBUF
. -
net.core.rmem_default, net.core.rmem_max
– default and max socket receive buffer size in bytes. Each socket getsrmem_default
reveive buffer size by default, and can request up tormem_max
with setsockopt optionSO_RCVBUF
.
Global system parameters are:
net.ipv4.udp_mem = "min pressure max"
– these are numbers of PAGES (4KB) available for all UDP sockets in the system. min, pressure and max controls how memory is managed, but main point is that max is maximum size in PAGES for all UDP bufers in system. These values are set on boot time (if sysctls are not explicitly set) according to available RAM size.net.ipv4.udp_rmem_min, net.ipv4.udp_wmem
– minimal size for receive/send buffers (in bytes), guaranteed for each socket, even if if buffer size of all UDP sockets exceeds pressure parameter innet.ipv4.udp_mem
.
Observing statistics with /proc/net/udp
and /proc/net/snmp
.
These are best described in this excellent blog post.