Ubuntu 14.04 nc 100%CPU使用率

我使用Ubuntu 14.04服务器(8核,16 GB RAM)来托管 PHP网站,MysqL和Redis.
PHP Web和MysqL的流量非常低(MysqL:每秒查询数:0.825). Redis每秒处理8011个命令.

今天我注意到nc仍位居榜首:

8348 root      20   0   11224    764    624 R 100.0  0.0   2277:01 nc                                                                                                                            
8319 root      20   0   11224    760    624 R 100.0  0.0   2277:59 nc                                                                                                                        
8324 root      20   0   11224    764    624 R 100.0  0.0   2278:09 nc                                                                                                                        
8344 root      20   0   11224    760    624 R 100.0  0.0   2277:07 nc

Stracing nc给出:

root@host:/home/user# strace -p 8348
Process 8348 attached
poll([{fd=3,events=POLLIN},{fd=-1}],2,1000) = 1 ([{fd=3,revents=POLLERR}])
poll([{fd=3,revents=POLLERR}])
intentionally cutted N lines from output

快速查找man poll可以获得有关轮询等待一组文件描述符中的一个准备好执行I / O的信息.

我如何找出文件描述符发生了什么(文件描述符问题?)并修复nc占用100%cpu

解决方法

我们最近遇到了类似的问题.我们有一个cron作业通过netcat在udp上发送一些redis统计数据,并且在上周将我们的一个石墨主机关闭了一段时间后,我们注意到我们的redis盒子上的cpu使用率暴涨.它似乎是netcat中的一个错误https://bugs.debian.org/cgi-bin/bugreport.cgi?bug=752931

我们运行的命令是这样的:

echo "{redis_metric}" | nc -w 1 -u ${graphite_host} 8125

使用’quit’选项(-q)而不是’timeout’选项(-w),似乎可以解决我们的问题:

echo "{redis_metric}" | nc -q 1 -u ${graphite_host} 8125

希望有所帮助!

相关文章

ubuntu退出redis的示例:指定配置文件方式启动源码redis:roo...
ubuntu中mysql改密码忘了的解决方法:1.在终端中切换到root权...
ubuntu安装mysql失败的解决方法原因:可能是原有的MySQL还有...
使用centos和ubuntu建站的区别有以下几点1.CentOS是Linux发行...
ubuntu图形界面和字符界面切换的方法:可以通过快捷键CTRL+A...
ubuntu中重启mysql失败的解决方法1.首先,在ubuntu命令行中,...