如何获得传递给在Unix / Linux系统正在运行的进程的命令行参数?如何获得传递给在Unix /

2019-05-12 20:24发布

在SunOS有pargs命令打印传递到正在运行的进程的命令行参数。

是否有其它Unix环境的任何类似的命令?

Answer 1:

有几种选择:

ps -fp <pid>
cat /proc/<pid>/cmdline

还有更多的信息中/proc/<pid>在Linux上,只要看看。

在其他Unix系统的东西可能会有所不同。 该ps命令将工作无处不在,在/proc的东西是操作系统特定的。 例如AIX上没有cmdline/proc



Answer 2:

这将这样的伎俩:

xargs -0 < /proc/<pid>/cmdline

没有xargs的,会有参数之间没有空格,因为它们已被转换为完全无效。



Answer 3:

对于Linux和Unix的系统,您可以使用ps -ef | grep process_name ps -ef | grep process_name得到完整的命令行,

在SunOS系统,如果你想获得你可以使用完整的命令行/usr/ucb/ps -auxww | grep -i process_name /usr/ucb/ps -auxww | grep -i process_name 。 确保在SunOSto得到你需要成为超级用户完整的命令行。

pargs -a PROCESS_ID 。 这将给传递给处理参数的详细列表。 它会给的参数的阵列中的输出像的argv [O]:第一变元的argv [1]:第二..等等..

我没有找到任何类似的命令,但我会给下面的命令来查看了把这样的tr '\0' '\n' < /proc/<pid>/environ在Linux环境。



Answer 4:

Linux

cat /proc/<pid>/cmdline

得到是你的过程(包括参数),但所有空格改为NULL字符的命令行。



Answer 5:

您可以使用pgrep-f (完整命令行)和-l (长说明):

pgrep -l -f PatternOfProcess

这种方法具有与任何其他反应的一个重要的区别:它适用于CygWin的 ,所以你可以用它来获取Windows下运行的所有进程的完整的命令行(EXECUTE AS 升高 ,如果你想了解任何升高/管理过程数据) 。 在Windows上这个产品的另一种方法是比较尴尬的, 例如 。
此外:在我的测试,和pgrep方式是只有工作 ,以获得Cygwin的蟒蛇内运行脚本的完整路径的系统



Answer 6:

印刷的另一变型/proc/PID/cmdline与Linux的空间是:

cat -v /proc/PID/cmdline | sed 's/\^@/\ /g' && echo

这样cat打印NULL字符如^@ ,然后你用一个空格替换它们sed ; echo打印换行符。



Answer 7:

而不是使用多个命令编辑流,只需使用一个 - tr转换一个字符到另一个:

tr '\0' ' ' </proc/<pid>/cmdline


Answer 8:

除了上述所有方法来将文本转换,如果简单地用“串”,它将使在不同的行默认的输出。 随着额外的好处,它也可能防止可能出现争夺终端的任何字符。

在一个命令中两个输出:

字符串的/ proc // CMDLINE的/ proc // ENVIRON

真正的问题是...有没有办法看到Linux的进程已经改变,因此CMDLINE包含改变文本,而不是已运行的实际命令的命令行方式。



Answer 9:

在Solaris

     ps -eo pid,comm

类似可以在UNIX等系统中使用。



Answer 10:

在Linux上,使用bash,输出引ARGS以便您可以编辑该命令,然后重新运行它

</proc/"${pid}"/cmdline xargs --no-run-if-empty -0 -n1 \
    bash -c 'printf "%q " "${1}"' /dev/null; echo

在Solaris,使用bash(测试了51年2月3日(1) - 释放)和不含GNU用户岛:

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击实施例:

{
## 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


Answer 11:

你可以简单地使用:

ps -o args= -f -p ProcessPid


Answer 12:

尝试在Linux终端“PS-N”。 这将显示:

1,所有进程运行,它们的命令行和它们的PID

  1. 该方案intiate的过程。

之后你就会知道杀哪个进程



Answer 13:

如果你想获得一个长期的,可能的(不知道是什么限制有),类似于Solaris的pargs ,你可以在Linux和OSX使用:

ps -ww -o pid,command [-p <pid> ... ]


文章来源: How to get the command line args passed to a running process on unix/linux systems?