阿里云-云小站(无限量代金券发放中)
【腾讯云】云服务器、云数据库、COS、CDN、短信等热卖云产品特惠抢购

nf_conntrack: table full, dropping packet解决方法

117次阅读
没有评论

共计 1026 个字符,预计需要花费 3 分钟才能阅读完成。

在添加 magent 代理后,做 memcached 测试的发现,如果并发很高,数据库的连接数居高不下,按理讲随着将 key 存入缓存中,连接数应该慢慢降下来才对,但是当并发低的时候却很正常。

由于在启动 memcached 时,加入了 -vvv 参数打印内部状态信息,查看日志:

29: going from conn_parse_cmd to conn_write
29: going from conn_write to conn_new_cmd
29: going from conn_new_cmd to conn_waiting
29: going from conn_waiting to conn_read
28: going from conn_new_cmd to conn_waiting
28: going from conn_waiting to conn_read
28: going from conn_read to conn_closing

从日志中可以看出,memcached 没有接受命令就关闭连接了。

再从 /var/log/messages 日志中发现如下信息刷屏:

kernel: nf_conntrack: table full, dropping packet

这是 iptables 的报错信息“连接跟踪表已满,开始丢包”,再想到网站那面将 memcached 的连接改为短连接,由于 iptables 会记录每个连接的跟踪信息,而连接关闭关闭过于频繁导致连接跟踪表满,出现丢包。

解决方法:

首先将 memcached 的连接方法改为长链接,然后再针对 nf_conntrack 进行修改,主要有以下几种方式:

1. 关闭防火墙

chkconfig iptables off
chkconfig ip6tables off
service iptables stop
service ip6tables stop

注意:在防火墙关闭的状态下,不要使用 iptables -L -vnx 来查看状态!因为这样会导致防火墙被启动,而且规则为空。虽然不会有任何拦截效果,但所有连接状态都会被记录,浪费资源且影响性能并可能导致防火墙主动丢包!

2. 加大 iptables 跟踪表大小,调整对应的系统参数

3. 使用裸表,不添加跟踪标志

4. 删除连接跟踪模块

具体的修改过程请参考 http://www.linuxidc.com/Linux/2015-06/118685.htm,这里说的比较详细。

本文永久更新链接地址 :http://www.linuxidc.com/Linux/2015-06/118684.htm

正文完
星哥说事-微信公众号
post-qrcode
 
星锅
版权声明:本站原创文章,由 星锅 2022-01-20发表,共计1026字。
转载说明:除特殊说明外本站文章皆由CC-4.0协议发布,转载请注明出处。
【腾讯云】推广者专属福利,新客户无门槛领取总价值高达2860元代金券,每种代金券限量500张,先到先得。
阿里云-最新活动爆款每日限量供应
评论(没有评论)
验证码
【腾讯云】云服务器、云数据库、COS、CDN、短信等云产品特惠热卖中