帮助中心 >  技术知识库 >  云服务器 >  服务器教程 >  解决Linux系统 ping: sendmsg: Operation not permitted 问题

解决Linux系统 ping: sendmsg: Operation not permitted 问题

2016-09-08 09:30:36 3601

问题现象

访问网站慢。执行ping结果如下图:

 

QQ???20160210164149.png

 

ping  127.0.0.1;ping: sendmsg: Operation not permitted

系统负核 1 以下,网络线路通畅,资料库无死锁进程;

系统日志出现大量:kernel: printk: xxxx messages suppressed.资讯。

dmesg 指令后发现大量以下资讯:

TCP: drop open request from 202.153.162.100/62751

printk: 78 messages suppressed.

问题原因

问题可能出在TCP/IP连结上,根据日志资讯查找资料介绍如下:

IP_conntrack表示连接跟踪数据库(conntrack database),代表NAT机器跟踪连接的数目,连接跟踪表能容纳多少记录是被一个变量控制的,它可由内核中的ip-sysctl函数设置。每一个跟踪连接表会占用350字节的内核存储空间,时间一长就会把默认的空间填满。

解决方案

1. 加大 ip_conntrack_max 值:

查出原本的 ip_conntrack_max 值,指令: cat /proc/sys/net/ipv4/ip_conntrack_max

写入理想的数值 (每一个 ip_conntrack buffer 会占用 292 Bytes)

指令: echo "数值" > /proc/sys/net/ipv4/ip_conntrack_max

例如: echo "163840" >/proc/sys/net/ipv4/ip_conntrack_max

这个效果是暂时的, 如果要每次开机都使用新的数值, 需将上述指令写入 /etc/rc.d/rc.local

或是在 /etc/sysctl.conf 加入: net.ipv4.ip_conntrack_max = 数值

或使用指令: sysctl -w net.ipv4.ip_conntrack_max=数值

2. 降低 ip_conntrack timeout 时间

重设:ip_conntrack_tcp_timeout_established (原值: 432000, 单位: 秒)

指令:echo "数值" > /proc/sys/net/ipv4/netfilter/ip_conntrack_tcp_timeout_established

例如:echo "180" > /proc/sys/net/ipv4/netfilter/ip_conntrack_tcp_timeout_established

3. 开启 tcp_syncookies

重设:tcp_syncookies (默认值 0)

例如:echo '1'> /proc/sys/net/ipv4/tcp_syncookies

4、经过以上设置后,系统日志出现一条:

 kernel: possible SYN flooding on port 80. Sending cookies.

后不再出现:kernel: printk: xxx messages suppressed. 的提示。访问网站明显感觉速度提升。



提交成功!非常感谢您的反馈,我们会继续努力做到更好!

这条文档是否有帮助解决问题?

非常抱歉未能帮助到您。为了给您提供更好的服务,我们很需要您进一步的反馈信息:

在文档使用中是否遇到以下问题: