我对 strace / netstat / 等很陌生。我正在使用此命令来跟踪处理我的请求 (telnet) 的 apache 进程,有没有办法稍微简化一下?
sudo strace -o /tmp/strace -f -s4096 -r -p $(netstat -antlp | \
grep $(lsof -p `pidof telnet` | grep TCP | \
perl -n -e'/localhost:(\d+)/ && print $1') | grep apache2 | \
perl -n -e'/ESTABLISHED (\d+)/ && print $1')
谢谢!
strace -p $(ss -npt|sed -n "/:$(ss -npt|sed -n '/telnet/s/^.*\?:\([0-9]\+\).*/\1/p') \+u/s/.*,\(.*\),.*/\1/p")
只要你只有一个
telnet
运行,这将strace
是相应的服务器(如果有的话)。如果没有(例如,您
telnet
最后访问了一个外部服务器),strace
将会失败strace: option requires an argument -- 'p'
或者,格式化以便于阅读,并且 OP 的 strace 标志完好无损:
细分,从最里面开始:
向我展示,在不将 IP 地址解析为 DNS 名称的情况下,所有活动的 TCP 连接。将其通过管道传输到 awk,它在以 结尾的任何行上打印第五个字段
/telnet
,其中字段由一个或多个空格和冒号分隔。该字段将是源端口。改进
| head -n 1
:可以通过在 awk的末尾或内部添加 a 来变得更加健壮;exit
,但是您的原始版本缺少等效的,所以我不想让这个更长。这
****
是我已经在上面解释过的部分。在这里,我正在寻找netstat -tnp
与我在上面发现的源端口具有相同端口且归 Apache 所有的任何行;当我找到它时,我打印第七个字段(由一个或多个空格或斜线分隔)。这是 Apache 孩子的 PID。改进:除了只返回一个 PID(通过与上述相同的方法),我能想象的最大的事情是在实际匹配 dport 时更具辨别力,而不是恰好适合模式的其他东西。通过向 FS (
-F
) 添加冒号可以很容易地做到这一点,但问题出现在混合 IPv4 和 IPv6 的情况下,地址本身可能有冒号,因此很快就会变得令人讨厌。这看起来非常可靠,尤其是尾随空格。这是您原始问题的直接副本;至少我没有修改它。
如果你允许我添加一些额外的字符,我运行的版本可能是:
我可以改进 Mark Henderson 的一点点,使用 $() 而不是 `` 并使用更好的 sed 删除 grep:
我个人认为反引号很难阅读;此外,它们不嵌套,不像 $() 语法
试试这个,希望它有所帮助: