217

在 SunOS 上,有一个pargs命令可以打印传递给正在运行的进程的命令行参数。

在其他 Unix 环境中是否有类似的命令?

4

13 回答 13

331

有几种选择:

ps -fp <pid>
cat /proc/<pid>/cmdline | sed -e "s/\x00/ /g"; echo

有更多/proc/<pid>关于 Linux 的信息,请看一下。

在其他 Unix 上,情况可能会有所不同。该ps命令将在任何地方工作,这些/proc东西是特定于操作系统的。例如在 AIX 上没有cmdline./proc

于 2009-05-04T20:26:54.397 回答
64

这可以解决问题:

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

如果没有 xargs,参数之间将没有空格,因为它们已被转换为 NUL。

于 2012-11-15T14:12:12.257 回答
24

完整的命令行

对于 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
于 2012-11-06T05:40:09.713 回答
18

您可以使用pgrep-f完整命令行)和-l(详细描述):

pgrep -l -f PatternOfProcess

此方法与任何其他响应都有一个至关重要的区别:它适用于CygWin,因此您可以使用它来获取在 Windows 下运行的任何进程的完整命令行(如果您想要有关任何提升/管理进程的数据,请以提升的方式执行) . 在 Windows 上执行此操作的任何其他方法都比较尴尬(例如)。
此外:在我的测试中, pgrep 方式是唯一能够获得在 CygWin 的 python 中运行的脚本的完整路径的系统。

于 2014-04-02T02:16:24.707 回答
16

Linux 上

cat /proc/<pid>/cmdline

获取进程的命令行(包括 args),但所有空格都更改为 NUL 字符。

于 2009-05-04T20:24:56.977 回答
4

/proc/PID/cmdline在 Linux 中使用空格打印的另一种变体是:

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

以这种方式cat打印NULL 字符,然后使用;^@将它们替换为空格。打印换行符。sedecho

于 2013-11-12T10:29:24.837 回答
3

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

tr '\0' ' ' </proc/<pid>/cmdline
于 2014-08-14T11:30:32.257 回答
2

您可以简单地使用:

ps -o args= -f -p ProcessPid
于 2017-02-02T17:28:17.220 回答
1

除了上述所有转换文本的方法外,如果您只是使用'strings',默认情况下会在不同的行上输出。额外的好处是,它还可以防止出现任何可能扰乱您的终端的字符。

两个输出都在一个命令中:

字符串 /proc//cmdline /proc//环境

真正的问题是......有没有办法查看 Linux 中已更改的进程的真实命令行,以便 cmdline 包含更改后的文本,而不是运行的实际命令。

于 2014-09-30T17:07:56.927 回答
1

ps -n在 linux 终端中尝试 。这将显示:

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

  1. 程序启动进程。

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

于 2014-11-24T02:43:43.417 回答
1

在 Solaris 上

     ps -eo pid,comm

类似的可以在类 Unix 系统上使用。

于 2016-05-19T06:28:37.013 回答
1

在 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 用户空间:

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
}

输出:

MATCH
于 2016-06-09T22:11:29.300 回答
0

如果您想获得尽可能长的时间(不确定有什么限制),类似于 Solaris 的pargs,您可以在 Linux 和 OSX 上使用它:

ps -ww -o pid,command [-p <pid> ... ]
于 2018-11-02T19:20:55.563 回答