[转帖]ipv6相关内核参数配置的优化实践
https://zhuanlan.zhihu.com/p/605217713
调整ARP缓存大小
这个参数通常需要在高负载的访问服务器上增加。比如繁忙的网络(或网关/防火墙 Linux 服务器),再比如集群规模大,node 和 pod 数量超多,往往需要增加内核的内部 ARP 缓存大小。
dmesg命令查看内核消息,当内核消息报:NEIGHBOUR: ARP_CACHE: NEIGHBOR TABLE OVERFLOW!
此内核消息表明 ARP 缓存已满。 ARP 缓存是 IP/MAC 地址绑定的查找表。
需要调大gc_thresh参数,下面是参考值:
下面是服务超过 6,000 个客户端的服务器的配置参考值:
sysctl -w net.ipv4.neigh.default.gc_thresh3=24456
sysctl -w net.ipv4.neigh.default.gc_thresh2=12228
sysctl -w net.ipv4.neigh.default.gc_thresh1=8192
sysctl -w net.ipv6.neigh.default.gc_thresh3=24456
sysctl -w net.ipv6.neigh.default.gc_thresh2=12228
sysctl -w net.ipv6.neigh.default.gc_thresh1=8192
除了上面的调整缓存大小的参数配置外,还可以调整下面两个参数以应对繁忙的网络,下面是200~500个客户端请求的网络服务器的配置参考值:
# 强制 gc 快速清理
net.ipv4.neigh.default.gc_interval = 3600
# 设置 ARP 缓存条目超时
net.ipv4.neigh.default.gc_stale_time = 3600
禁用ipv6
如果不使用 IPv6 或双栈,建议禁用 IPv6 以减少系统的攻击面。
编辑 /etc/default/grub 并将 ipv6.disable=1 添加到 GRUB_CMDLINE_LINUX 参数:GRUB_CMDLINE_LINUX=’ipv6.disable=1’运行以下命令更新 grub2 配置:# update-grub
除了grub方式,还可以通过在 /etc/sysctl.conf 加上
net.ipv6.conf .all.disable_ipv6 = 1
net.ipv6.conf.default.disable_ipv6 = 1
执行 /sbin/sysctl -p 使其生效。
转发
IP 转发是操作系统在一个接口上接受传入网络数据包的能力,识别它不是针对系统本身的,而是应该转发到另一个网络,然后相应地转发。
如果我们要设置 Linux 路由器/网关 或 VPN 服务器,就需要必须开启转发。
net.ipv4.ip_forward=1
net.ipv6.conf.all.forwarding=1
若不需要ip转发,比如不用做Linux 路由器/网关 或 VPN 服务器,将值设为0。
高并发场景,扩大源端口范围
高并发场景,对于 client 来说会使用大量源端口,源端口范围从 net.ipv4.ip_local_port_range 这个内核参数中定义的区间随机选取,在高并发环境下,端口范围小容易导致源端口耗尽,使得部分连接异常。通常 Pod 源端口范围默认是 32768-60999,建议将其扩大,调整为 1024-65535:
net.ipv4.ip_local_port_range=”1024 65535”。
该配置参数修改后对ipv6同样生效。
bridge-nf-call-iptables
若该K8S节点网络使用了Linux网桥,bridge-nf-call-iptables参数需要设置为1。
net.bridge.bridge-nf-call-iptables=1
否则会因为DNAT回包异常而丢包。
调整tcp全连接连接队列的大小
TCP 全连接队列的长度如果过小,在高并发环境可能导致队列溢出,使得部分连接无法建立。
如果因全连接队列溢出导致了丢包,从统计的计数上是可以看出来的:
# 用 netstat 查看统计
$ netstat -s | grep -E 'overflow|drop'
12178939 times the listen queue of a socket overflowed
12247395 SYNs to LISTEN sockets dropped
高并发环境可以考虑将其改到 65535:
sysctl -w net.core.somaxconn=65535
调整UDP缓冲区
UDP socket 的发送和接收缓冲区是有上限的,如果缓冲区较小,高并发环境可能导致缓冲区满而丢包,通过下面的命令可以看出来:
# 使用 netstat 查看统计
$ netstat -s | grep "buffer errors"
429469 receive buffer errors
23568 send buffer errors
net.core.wmem_default 和 net.core.wmem_max 这两个内核参数,分别表示缓冲区的默认大小和最大上限。
调整conntrack 表
内核日志:
# demsg
$ journalctl -k | grep "nf_conntrack: table full"
nf_conntrack: nf_conntrack: table full, dropping packet
若有以上报错,证明 conntrack 表满了,需要调大 conntrack 表:
sysctl -w net.netfilter.nf_conntrack_max=1000000
主机无法ping通ipv6网关
有几台业务虚机,经常会出现ipv6无法访问自己网关,要重启机器才可以修复。
原因
分析dmesg日志有如下信息:
[113050.599558] Route cache is full: consider increasing sysctl net.ipv6.route.max_size.
[113052.663065] Route cache is full: consider increasing sysctl net.ipv6.route.max_size.
查看该内配参数配置:
$ sudo sysctl net.ipv6.route.max_size
net.ipv6.route.max_size = 4096
net.ipv6.route.max_size 该内核参数的作用是设置目的地条目的缓存。当 Linux 内核解析到目的地的路由时,它会将其放入缓存中以备将来使用。
net.ipv6.route.max_size 默认为 4096。IPv4 的等效设置默认为“百万”,甚至在现代内核中动态调整大小。
解决方案:将内核参数net.ipv6.route.max_size置为2147483647。默认为4096。
可以将该值调足够大,比如 2147483647
vim /etc/sysctl.conf
做以下配置
net.ipv6.route.max_size = 2147483647
然后执行sysctl -p
可能的话,再重启下网络。
ipv6默认路由丢失:
重启network或者网卡后,ipv6默认路由存在(下一跳为fe80开头的默认路由)

大约8分钟左右,fe80这条默认路由丢失。
原因:
accept_ra这个内核参数默认为1。由于主机开启了路由转发,导致ce1800v发送到主机RA参数不生效。

解决方案:
将accept_ra置为2。
重启网卡或者network时,ipv6默认路由没有立即生成问题
重启network时,ipv6路由没有立即获取到fe80的默认路由,如下图:

大约7分钟左右,主机会生成到fe80的路由。此时间和华为RA通告的时间间隔基本一致。
原因:
主机开启ipv6路由转发(net.ipv6.conf.all.forwarding=1)后,系统不再主动发起RS请求报文。
解决方案:
关闭ipv6路由转发(net.ipv6.conf.all.forwarding=0)。
[转帖]ipv6相关内核参数配置的优化实践的更多相关文章
- (转)linux内核参数注释与优化
linux内核参数注释与优化 原文:http://blog.51cto.com/yangrong/1321594 http://oldboy.blog.51.cto.com/2561410/13364 ...
- Linux内核参数配置
Linux在系统运行时修改内核参数(/proc/sys与/etc/sysctl.conf),而不需要重新引导系统,这个功能是通过/proc虚拟文件系统实现的. 在/proc/sys目录下存放着大多数的 ...
- linux (centos) 单机50w+链接 内核参数配置
1 突破系统最大fd 查看当前文件描述符的限制数目的命令: ulimit -n .修改文件描述符的限制数目 2.1 临时改变当前会话: ulimit -n 2.2 永久变更需要下面两个步骤: ./ ...
- linux内核参数注释与优化
目录 1.linux内核参数注释 2.两种修改内核参数方法 3.内核优化参数生产配置 参数解释由网络上收集整理,常用优化参数对比了网上多个实际应用进行表格化整理,使查看更直观. 学习linux也有不少 ...
- ORA-27104: system-defined limits for shared memory was misconfigured与Linux内核参数配置有关的案例
```[oracle@WWJD01 ~]$ sqlplus / as sysdba SQL*Plus: Release 12.2.0.1.0 Production on Fri Sep 21 15:1 ...
- spark 指定相关的参数配置 num-executor executor-memory executor-cores
num-executors参数说明:该参数用于设置Spark作业总共要用多少个Executor进程来执行.Driver在向YARN集群管理器申请资源时,YARN集群管理器会尽可能按照你的设置来在集群的 ...
- Linux 数据库相关内核参数
cat >>/etc/sysctl.conf <<EOOF # add by digoal.zhou fs.aio-max-nr = 1048576 fs. ...
- Oracle 安装时候的网络相关内核参数
http://www.cnblogs.com/gaojian/archive/2012/10/12/2721284.html http://blog.chinaunix.net/uid-2442641 ...
- 我的 archlinux 内核参数配置
title Arch Linux linux /vmlinuz-linux initrd /amd-ucode.img initrd /initramfs-linux.img options root ...
- Hbase 参数配置及优化
From:http://www.open-open.com/lib/view/open1346684547787.html 接触hbase已有半年的时间,查了很多资料,也参考了很多别人心得,也希望把自 ...
随机推荐
- 神经网络优化篇:详解梯度的数值逼近(Numerical approximation of gradients)
在实施backprop时,有一个测试叫做梯度检验,它的作用是确保backprop正确实施.因为有时候,虽然写下了这些方程式,却不能100%确定,执行backprop的所有细节都是正确的.为了逐渐实现梯 ...
- Windows 激活系统提示0x80072F8F错误代码的解决方法(刷新你的认知)
Server2008.Server2012.Server2016.Win7.Win10都适用 https://blog.csdn.net/happyxjbf/article/details/10591 ...
- C语言基础之因子分解
要求: 从键盘输入一个正整数,然后将该整数分解为1和各个质因子的相乘,如果输入的整数本身就是质数,则应分解为1和该数本身相乘. 输出格式: 因子分解,因子由小到大输出. 如:1* 2* 2* 3 代码 ...
- 面试题:Java中的引用类型有哪几种?特点是什么?
Java中引用类型及特点 强 引用: 最普通的引用 Object o = new Object() 软 引用: 垃圾回收器, 内存不够的时候回收 (缓存) 弱 引用: 垃圾回收器看见就会回收 (防止内 ...
- Python借助企业微信群机器人发送消息、图片和文件
企业微信功能日益强大,腾讯官方也提供了丰富的API供开发者实现企业微信的很多自动化场景.比如,如何给某个企业微信群发送消息.图片或者文件,甚至@指定群用户?别急,看小爬君轻松教会大家. Step1:在 ...
- POJ 3003 DP 寻路 记录路径
POJ 3003 DP 寻路 记录路径 我一开始把M看成是每个a_i的上限了,这是致命的,因为这个题dfs暴力搜索+剪枝是过不了的因为M<=40,全部状态有2的四十次幂. 正解是DP,设dp[i ...
- ChatGPT 同类工具推荐
原文: https://openaigptguide.com/chatgpt-similar%20software/ ChatGPT是一款由美国OpenAI公司开发的人工智能语言模型,类似的软件有: ...
- 【华为云技术分享】空间异常即刻诊断,华为云数据管理服务DAS又出新招
摘要:华为云数据管理服务DAS提供的云DBA智能化运维平台于日前发布了空间&元数据分析特性,支持查看实例空间异常列表.实例空间概况.数据库列表信息,帮助用户及时发现数据库中的空间和元数据异常, ...
- 4大焕新,华为云CCE带你感受容器化上云体验
本文分享自华为云社区<华为云CCE邀您共同打造最佳容器化上云体验>,作者:云容器大未来 . 在容器化日益成为中大型企业上云主流选择的情况下,容器服务如何能帮助用户更简单快捷的上云.高效可信 ...
- 云小课|RDS for MySQL参数模板一键导入导出,参数配置轻松搞定
摘要:云数据库RDS for MySQL支持参数模板的导入和导出功能. 本文分享自华为云社区<[云小课][第56课]RDS for MySQL参数模板一键导入导出,参数配置轻松搞定>,作者 ...