Aiv*_*ras 5 ubuntu cpu-usage netcat redis
我使用Ubuntu 14.04服务器(8核,16 GB RAM)来托管PHP网站,MySQL和Redis.PHP Web和MySQL的流量非常低(MySQL:每秒查询数:0.825).Redis每秒处理8011个命令.
今天我注意到nc保持在最高位置top:
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
Run Code Online (Sandbox Code Playgroud)
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, events=POLLIN}, {fd=-1}], 2, 1000) = 1 ([{fd=3, revents=POLLERR}])
poll([{fd=3, events=POLLIN}, {fd=-1}], 2, 1000) = 1 ([{fd=3, revents=POLLERR}])
intentionally cutted N lines from output
Run Code Online (Sandbox Code Playgroud)
快速查找man poll给我的信息poll waits for one of a set of file descriptors to become ready to perform I/O.
我如何找出文件描述符发生了什么(文件描述符问题?)并修复nc占用100%CPU?
我们最近遇到了类似的问题.我们有一个cron作业,通过udp发送一些redis统计数据到石墨netcat,并在上周将我们的一个石墨主机停机一段时间之后,我们注意到我们的redis盒子上的CPU使用率暴涨.它似乎是一个错误netcat:https://bugs.debian.org/cgi-bin/bugreport.cgi?video = 752931
我们运行的命令是这样的:
echo "{redis_metric}" | nc -w 1 -u ${graphite_host} 8125
Run Code Online (Sandbox Code Playgroud)
使用'quit'选项(-q)而不是'timeout'选项(-w),似乎可以解决我们的问题:
echo "{redis_metric}" | nc -q 1 -u ${graphite_host} 8125
Run Code Online (Sandbox Code Playgroud)
希望有所帮助!