在SunOS上有 pargs 命令,用于打印传递给正在运行的进程的命令行参数 .
pargs
在其他Unix环境中是否有类似的命令?
在 Linux
cat /proc/<pid>/cmdline
得到你是进程的命令行(包括args),但是所有的空格都改为NUL字符 .
在Solaris上
ps -eo pid,comm
类似的可以在类似unix的系统上使用 .
而不是使用多个命令来编辑流,只需使用一个-tr将一个字符转换为另一个字符:
tr '\0' ' ' </proc/<pid>/cmdline
有几种选择:
ps -fp <pid> cat /proc/<pid>/cmdline
在Linux上的 /proc/<pid> 中有更多信息,请看一下 .
/proc/<pid>
在其他Unix上,事情可能会有所不同 . ps 命令可以在任何地方使用, /proc 内容是特定于操作系统的 . 例如,在AIX上, /proc 中没有 cmdline .
ps
/proc
cmdline
对于Linux和Unix系统,您可以使用 ps -ef | grep process_name 来获取完整的命令行,
ps -ef | grep process_name
在SunOS系统上,如果要获得完整的命令行,可以使用 /usr/ucb/ps -auxww | grep -i process_name . 确保在SunOSto中获得成为超级用户所需的完整命令行 .
/usr/ucb/ps -auxww | grep -i process_name
pargs -a PROCESS_ID . 这将给出传递给进程的参数的详细列表 . 它将在输出中给出参数数组,如argv [o]:first argumen argv [1]:second .. so ..
pargs -a PROCESS_ID
我没有找到任何类似的命令,但我会给出以下命令来获取Linux环境中的 tr '\0' '\n' < /proc/<pid>/environ 输出 .
tr '\0' '\n' < /proc/<pid>/environ
在Linux中使用空格打印 /proc/PID/cmdline 的另一种变体是:
/proc/PID/cmdline
cat -v /proc/PID/cmdline | sed 's/\^@/\ /g' && echo
以这种方式 cat 将NULL characters打印为 ^@ ,然后使用 sed 将其替换为空格; echo 打印换行符 .
cat
^@
sed
echo
在Linux上,使用bash,输出为引用的args,以便您可以编辑命令并重新运行它
</proc/"${pid}"/cmdline xargs --no-run-if-empty -0 -n1 \ bash -c 'printf "%q " "${1}"' /dev/null; echo
在Solaris上,使用bash(使用3.2.51(1)-release测试)并且没有gnu userland:
IFS=$'\002' tmpargs=( $( pargs "${pid}" \ | /usr/bin/sed -n 's/^argv\[[0-9]\{1,\}\]: //gp' \ | tr '\n' '\002' ) ) for tmparg in "${tmpargs[@]}"; do printf "%q " "$( echo -e "${tmparg}" )" done; echo
Linux bash示例(粘贴到终端):
{ ## setup intial args argv=( /bin/bash -c '{ /usr/bin/sleep 10; echo; }' /dev/null 'BEGIN {system("sleep 2")}' "this is" \ "some" "args "$'\n'" that" $'\000' $'\002' "need" "quot"$'\t'"ing" ) ## run in background "${argv[@]}" & ## recover into eval string that assigns it to argv_recovered eval_me=$( printf "argv_recovered=( " </proc/"${!}"/cmdline xargs --no-run-if-empty -0 -n1 \ bash -c 'printf "%q " "${1}"' /dev/null printf " )\n" ) ## do eval eval "${eval_me}" ## verify match if [ "$( declare -p argv )" == "$( declare -p argv_recovered | sed 's/argv_recovered/argv/' )" ]; then echo MATCH else echo NO MATCH fi }
输出:
MATCH
Solaris Bash示例:
{ ## setup intial args argv=( /bin/bash -c '{ /usr/bin/sleep 10; echo; }' /dev/null 'BEGIN {system("sleep 2")}' "this is" \ "some" "args "$'\n'" that" $'\000' $'\002' "need" "quot"$'\t'"ing" ) ## run in background "${argv[@]}" & pargs "${!}" ps -fp "${!}" declare -p tmpargs eval_me=$( printf "argv_recovered=( " IFS=$'\002' tmpargs=( $( pargs "${!}" \ | /usr/bin/sed -n 's/^argv\[[0-9]\{1,\}\]: //gp' \ | tr '\n' '\002' ) ) for tmparg in "${tmpargs[@]}"; do printf "%q " "$( echo -e "${tmparg}" )" done; echo printf " )\n" ) ## do eval eval "${eval_me}" ## verify match if [ "$( declare -p argv )" == "$( declare -p argv_recovered | sed 's/argv_recovered/argv/' )" ]; then echo MATCH else echo NO MATCH fi }
你可以简单地使用:
ps -o args= -f -p ProcessPid
除了上述所有转换文本的方法之外,如果你只是使用'strings',它默认会在单独的行上输出 . 有了额外的好处,它还可以防止任何可能扰乱终端出现的字符 .
两个输出都在一个命令中:
strings / proc // cmdline / proc // environ
真正的问题是......有没有办法在Linux中查看已经改变的进程的真实命令行,以便cmdline包含已更改的文本而不是运行的实际命令 .
在linux终端尝试“ps -n” . 这将显示:
1.所有进程运行,命令行和它们的PID
之后你会知道要杀死哪个进程
这样就可以了:
xargs -0 < /proc/<pid>/cmdline
如果没有xargs,参数之间就不会有空格,因为它们已经转换为NUL .
如果你想获得尽可能长的(不确定有什么限制),类似于Solaris'pargs,你可以在Linux和OSX上使用它:
ps -ww -o pid,command [-p <pid> ... ]
您可以将 pgrep 与 -f (完整命令行)和 -l (长描述)一起使用:
pgrep
-f
-l
pgrep -l -f PatternOfProcess
此方法与任何其他响应有着重要的区别:它适用于CygWin,因此您可以使用它来获取在Windows下运行的任何进程的完整命令行(如果您需要有关任何提升/管理进程的数据,则执行elevated) . 在Windows上执行此操作的任何其他方法都更加尴尬,for example .此外:在我的测试中,pgrep方式已经 the only system that worked 来获取在CygWin的python中运行的脚本的完整路径 .
13 回答
在 Linux
得到你是进程的命令行(包括args),但是所有的空格都改为NUL字符 .
在Solaris上
类似的可以在类似unix的系统上使用 .
而不是使用多个命令来编辑流,只需使用一个-tr将一个字符转换为另一个字符:
有几种选择:
在Linux上的
/proc/<pid>
中有更多信息,请看一下 .在其他Unix上,事情可能会有所不同 .
ps
命令可以在任何地方使用,/proc
内容是特定于操作系统的 . 例如,在AIX上,/proc
中没有cmdline
.对于Linux和Unix系统,您可以使用
ps -ef | grep process_name
来获取完整的命令行,在SunOS系统上,如果要获得完整的命令行,可以使用
/usr/ucb/ps -auxww | grep -i process_name
. 确保在SunOSto中获得成为超级用户所需的完整命令行 .pargs -a PROCESS_ID
. 这将给出传递给进程的参数的详细列表 . 它将在输出中给出参数数组,如argv [o]:first argumen argv [1]:second .. so ..我没有找到任何类似的命令,但我会给出以下命令来获取Linux环境中的
tr '\0' '\n' < /proc/<pid>/environ
输出 .在Linux中使用空格打印
/proc/PID/cmdline
的另一种变体是:以这种方式
cat
将NULL characters打印为^@
,然后使用sed
将其替换为空格;echo
打印换行符 .在Linux上,使用bash,输出为引用的args,以便您可以编辑命令并重新运行它
在Solaris上,使用bash(使用3.2.51(1)-release测试)并且没有gnu userland:
Linux bash示例(粘贴到终端):
输出:
Solaris Bash示例:
输出:
你可以简单地使用:
除了上述所有转换文本的方法之外,如果你只是使用'strings',它默认会在单独的行上输出 . 有了额外的好处,它还可以防止任何可能扰乱终端出现的字符 .
两个输出都在一个命令中:
strings / proc // cmdline / proc // environ
真正的问题是......有没有办法在Linux中查看已经改变的进程的真实命令行,以便cmdline包含已更改的文本而不是运行的实际命令 .
在linux终端尝试“ps -n” . 这将显示:
1.所有进程运行,命令行和它们的PID
之后你会知道要杀死哪个进程
这样就可以了:
如果没有xargs,参数之间就不会有空格,因为它们已经转换为NUL .
如果你想获得尽可能长的(不确定有什么限制),类似于Solaris'pargs,你可以在Linux和OSX上使用它:
您可以将
pgrep
与-f
(完整命令行)和-l
(长描述)一起使用:此方法与任何其他响应有着重要的区别:它适用于CygWin,因此您可以使用它来获取在Windows下运行的任何进程的完整命令行(如果您需要有关任何提升/管理进程的数据,则执行elevated) . 在Windows上执行此操作的任何其他方法都更加尴尬,for example .
此外:在我的测试中,pgrep方式已经 the only system that worked 来获取在CygWin的python中运行的脚本的完整路径 .