我使用Ubuntu 14.04服务器(8核,16 GB RAM)来托管
PHP网站,MysqL和Redis.
PHP Web和MysqL的流量非常低(MysqL:每秒查询数:0.825). Redis每秒处理8011个命令.
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
解决方法
我们最近遇到了类似的问题.我们有一个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
希望有所帮助!