通过修改net.ipv4.udp_mem
参数的大小,改变内核对UDP内存的管理策略,从而控制系统的UDP数据包的缓存和处理能力。
net.ipv4.udp_mem
是一个由3元整数组构成[min pressure max]
,这些值分别表示UDP协议栈在不同状态下的内存使用限制。这三个值定义了内存的阈值,单位为Page
(内核页,通常1内核页大小为4KiB),含义如下:
min
: 内核开始回收内存的阈值。当系统的UDP内存使用量达到这个值时,内核将开始回收内存,以避免过度使用。pressure
: 内核内存使用的软限制。超过这个值时,UDP会调节其内存消耗并进入内存压力模式;当内存消耗降到min
以下时,UDP将退出内存压力模式。max
: 内核内存使用的硬限制,即允许所有UDP Socket用于排队缓冲数据报的页面量。超过这个值时,系统会拒绝分配Socket。网络负载较重的场景
在需要处理大量的UDP数据包,如实时视频流或大规模数据传输场景,服务器可能会遇到UDP套接字内存总和达到上限导致丢包的问题。此时,可以参考如下方案进行调整:
min
: 设置该参数为较高值,减少由于频繁的内存回收对高流量请求的影响。pressure
: 设置该参数值为min
参数值的4/3倍。max
: 设置该参数值为pressure
的2倍。网络负载较轻的场景
在进行基本的内部网络服务,UDP使用较少,如文件传输和打印服务场景,服务器可能会由于内存回收阈值较高,出现不必要的内存占用问题。此时,可以参考如下方案进行调整:
min
: 设置该参数为较低的值,降低触发内存回收的阈值,避免不必要的内存占用。pressure
: 设置该参数值为min
的4/3倍。max
: 设置该参数值为pressure
的2倍。本方式可在操作系统运行过程中临时更改参数,每次重启实例后都需要重新配置。
net.ipv4.udp_mem
参数当前值。回显示例:cat /proc/sys/net/ipv4/udp_mem
net.ipv4.udp_mem
参数值。说明
请将42396 56530 84792
替换为业务所需的实际值,详情可参考关于net-ipv4-udp-mem参数。
echo "42396 56530 84792" > /proc/sys/net/ipv4/udp_mem
本方式可在操作系统运行过程中永久修改参数值,重启实例后无需再次配置。
回显示例:sysctl net.ipv4.udp_mem
net.ipv4.udp_mem
参数值。
vim /etc/sysctl.d/net_udp.conf
i
键进入编辑模式,在文末添加如下内容。说明
请将42396 56530 84792
替换为业务所需的实际值,详情可参考关于net-ipv4-udp-mem参数。
net.ipv4.udp_mem = 42396 56530 84792
Esc
键退出编辑模式,输入:wq
保存并退出文件。sysctl -p /etc/sysctl.d/net_udp.conf