如何在unix / linux系统上将命令行args传递给正在运行的进程?

时间:2009-05-04 20:18:13

标签: linux unix aix hp-ux sunos

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

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

13 个答案:

答案 0 :(得分:276)

有几种选择:

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

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

在其他Unix上,事情可能会有所不同。 ps命令可以在任何地方使用,/proc内容是特定于操作系统的。例如,在AIX上cmdline中没有/proc

答案 1 :(得分:60)

这样可以解决问题:

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

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

答案 2 :(得分:16)

完整命令行

对于Linux&amp;在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

答案 3 :(得分:14)

Linux

cat /proc/<pid>/cmdline

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

答案 4 :(得分:12)

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

pgrep -l -f PatternOfProcess

此方法与其他任何响应都有重要区别:它适用于 CygWin ,因此您可以使用它来获取在Windows下运行的任何进程的完整命令行(如果您需要有关任何提升/管理进程的数据,请执行elevated。在Windows上执行此操作的任何其他方法都更加笨拙,for example 此外:在我的测试中,pgrep方式是唯一有效的系统,以获取在CygWin的python 中运行的脚本的完整路径。

答案 5 :(得分:3)

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

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

以这种方式catNULL characters打印为^@,然后使用sed替换为空格; echo打印换行符。

答案 6 :(得分:2)

不要使用多个命令来编辑流,只需使用一个 - tr将一个字符翻译成另一个字符:

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

答案 7 :(得分:1)

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

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

strings / proc // cmdline / proc // environ

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

答案 8 :(得分:1)

在Solaris上

     ps -eo pid,comm

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

答案 9 :(得分: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)-exlease测试)并且没有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
}

输出:

MATCH

答案 10 :(得分:1)

您可以简单地使用:

ps -o args= -f -p ProcessPid

答案 11 :(得分:0)

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

1.所有进程运行,命令行及其PID

  1. 程序启动流程。
  2. 之后您将知道要杀死哪个进程

答案 12 :(得分:0)

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

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