AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / server / 问题 / 400602
Accepted
Andrei Serdeliuc
Andrei Serdeliuc
Asked: 2012-06-21 07:30:03 +0800 CST2012-06-21 07:30:03 +0800 CST 2012-06-21 07:30:03 +0800 CST

你会如何简化这个命令?

  • 772

我对 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')

谢谢!

bash command-line-interface strace
  • 4 4 个回答
  • 729 Views

4 个回答

  • Voted
  1. Pierre Carrier
    2012-07-04T09:03:42+08:002012-07-04T09:03:42+08:00

    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'

    • 2
  2. BMDan
    2012-07-04T13:10:17+08:002012-07-04T13:10:17+08:00
    strace -p $(netstat -tnp|awk -F'[ /]+' "/:$(netstat -tnp|awk -F'[ :]+' 
    "/\/telnet/{print \$5}") /&&/apache2/{print \$7}")
    

    或者,格式化以便于阅读,并且 OP 的 strace 标志完好无损:

    sudo strace -o /tmp/strace -f -s4096 -r -p $(netstat -tnp | \
    awk -F'[ /]+' "/:$(netstat -tnp | awk -F'[ :]+' "/\/telnet/ \
    {print \$5}") / && /apache2/ {print \$7}")
    

    细分,从最里面开始:

    netstat -tnp | awk -F'[ :]+' "/\/telnet/ {print \$5}"
    

    向我展示,在不将 IP 地址解析为 DNS 名称的情况下,所有活动的 TCP 连接。将其通过管道传输到 awk,它在以 结尾的任何行上打印第五个字段/telnet,其中字段由一个或多个空格和冒号分隔。该字段将是源端口。

    改进| head -n 1:可以通过在 awk的末尾或内部添加 a 来变得更加健壮;exit,但是您的原始版本缺少等效的,所以我不想让这个更长。

    netstat -tnp | awk -F'[ /]+' "/:**** / && /apache2/ {print \$7}")
    

    这****是我已经在上面解释过的部分。在这里,我正在寻找netstat -tnp与我在上面发现的源端口具有相同端口且归 Apache 所有的任何行;当我找到它时,我打印第七个字段(由一个或多个空格或斜线分隔)。这是 Apache 孩子的 PID。

    改进:除了只返回一个 PID(通过与上述相同的方法),我能想象的最大的事情是在实际匹配 dport 时更具辨别力,而不是恰好适合模式的其他东西。通过向 FS ( -F) 添加冒号可以很容易地做到这一点,但问题出现在混合 IPv4 和 IPv6 的情况下,地址本身可能有冒号,因此很快就会变得令人讨厌。这看起来非常可靠,尤其是尾随空格。

    sudo strace -o /tmp/strace -f -s4096 -r -p
    

    这是您原始问题的直接副本;至少我没有修改它。

    如果你允许我添加一些额外的字符,我运行的版本可能是:

    sudo strace -o /tmp/strace -f -s4096 -r -p $(netstat -tnp | \
    awk -F'[ /]+' "/:$(netstat -tnp | awk -F'[ :]+' "/\/telnet/ \
    {print \$5;exit}") / && /apache2/ {print \$7;exit}")
    
    • 1
  3. Best Answer
    dotplus
    2012-07-06T06:50:11+08:002012-07-06T06:50:11+08:00

    我可以改进 Mark Henderson 的一点点,使用 $() 而不是 `` 并使用更好的 sed 删除 grep:

    sudo strace -o /tmp/strace -f -s4096 -r -p $(netstat -antlp | \
       sed -e "/telnet/s/^.*ESTABLISHED\ \|\/.*$//g")
    

    我个人认为反引号很难阅读;此外,它们不嵌套,不像 $() 语法

    • 1
  4. Logic Wreck
    2012-07-03T09:02:11+08:002012-07-03T09:02:11+08:00

    试试这个,希望它有所帮助:

    sudo strace -o /tmp/strace -f -s4096 -r -p `netstat -antlp | \
      grep telnet | sed -e "s/^.*ESTABLISHED\ \|\/.*$//g"`
    
    • 0

相关问题

  • Mac OS X:从 python 脚本中更改 $PATH

  • Bash 脚本:要求脚本以 root 身份运行(或使用 sudo)

  • crontab ifconfig 什么都不输出

  • 使用命令行工具按排序顺序计算重复项

  • 是否有 bash 等效于 ruby​​ 的“一些内容#{foo}”?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    新安装后 postgres 的默认超级用户用户名/密码是什么?

    • 5 个回答
  • Marko Smith

    SFTP 使用什么端口?

    • 6 个回答
  • Marko Smith

    命令行列出 Windows Active Directory 组中的用户?

    • 9 个回答
  • Marko Smith

    什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同?

    • 3 个回答
  • Marko Smith

    如何确定bash变量是否为空?

    • 15 个回答
  • Martin Hope
    Tom Feiner 如何按大小对 du -h 输出进行排序 2009-02-26 05:42:42 +0800 CST
  • Martin Hope
    Noah Goodrich 什么是 Pem 文件,它与其他 OpenSSL 生成的密钥文件格式有何不同? 2009-05-19 18:24:42 +0800 CST
  • Martin Hope
    Brent 如何确定bash变量是否为空? 2009-05-13 09:54:48 +0800 CST
  • Martin Hope
    cletus 您如何找到在 Windows 中打开文件的进程? 2009-05-01 16:47:16 +0800 CST

热门标签

linux nginx windows networking ubuntu domain-name-system amazon-web-services active-directory apache-2.4 ssh

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve