在SunOS上,有一个名为pargs
命令,它会打印运行进程所传递的命令行参数。
其他Unix环境中有类似的命令吗?
有几个选项:
ps -fp <pid>
cat /proc/<pid>/cmdline | sed -e "s/\x00/ /g"; echo
在Linux中,/proc/<pid>
中有更多信息,请查看。
在其他Unix上可能会有所不同。 ps
命令可以在任何地方使用,但/proc
是特定于操作系统的。例如,在AIX上,/proc
中没有cmdline
。
ps -ww -fp <pid>
)来指定宽输出,因为如果有多个命令,它们可能会被截断。 - Silfheedcat /proc/<pid>/cmdline
在 Cygwin 上也适用,因为在 ps
的任何选项中都不显示命令行参数。 - lechupargs
,命令是ps -o args -p <pid>
,它只会打印出args
,或者如果你只需要查看cmd
,可以使用选项-o cmd
。尝试读取/proc/<pid>/cmdline
对于非特权用户并不总是有效的。ps
工具则可以工作。 - alvits这样做就可以了:
xargs -0 < /proc/<pid>/cmdline
如果没有使用xargs,参数之间将没有空格,因为它们已被转换为NUL字符。
对于Linux和Unix系统,您可以使用ps -ef | grep process_name
获取完整的命令行。
在SunOS系统上,如果您想要获取完整的命令行,则可以使用
/usr/ucb/ps -auxww | grep -i process_name
要获取完整的命令行,您需要成为超级用户。
pargs -a PROCESS_ID
将详细列出传递给进程的参数列表。它将以以下方式输出参数数组:
argv[o]: first argument
argv[1]: second..
argv[*]: and so on..
我没有在Linux中找到任何类似的命令,但是我会使用以下命令来获得类似的输出:
tr '\0' '\n' < /proc/<pid>/environ
ps -ef
。 - Timofey在Linux上
cat /proc/<pid>/cmdline
该函数输出进程 <pid>
的命令行(包括参数),每个记录以一个 NUL
字符作为结束符。
一个 Bash Shell 示例:
$ mapfile -d '' args < /proc/$$/cmdline
$ echo "#${#args[@]}:" "${args[@]}"
#1: /bin/bash
$ echo $BASH_VERSION
5.0.17(1)-release
pgrep from procps-ng 3.3.15
和 3.3.12
对我不起作用。只打印pid和程序名称,没有参数。 - Socowi/proc/PID/cmdline
的另一种变体是:cat -v /proc/PID/cmdline | sed 's/\^@/\ /g' && echo
通过这种方式,cat
以 ^@
的形式打印 NULL 字符,然后你可以使用 sed
将其替换为一个空格;echo
打印一个新行。
与其使用多个命令来编辑流,不如只使用一个 - tr将一个字符转换为另一个字符:
tr '\0' ' ' </proc/<pid>/cmdline
ps -eo pid,args
命令可以打印进程的PID和完整命令行。
ps -o args= -f -p ProcessPid
</proc/"${pid}"/cmdline xargs --no-run-if-empty -0 -n1 \
bash -c 'printf "%q " "${1}"' /dev/null; echo
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
{
## 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
}
输出:
MATCH