Programing

유닉스 / 리눅스 시스템에서 실행중인 프로세스로 커맨드 라인 인수를 얻는 방법?

crosscheck 2020. 5. 16. 11:13
반응형

유닉스 / 리눅스 시스템에서 실행중인 프로세스로 커맨드 라인 인수를 얻는 방법?


SunOS에는 pargs실행중인 프로세스에 전달 된 명령 행 인수를 인쇄하는 명령이 있습니다.

다른 유닉스 환경에서도 비슷한 명령이 있습니까?


몇 가지 옵션이 있습니다.

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

/proc/<pid>리눅스 에는 더 많은 정보가 있습니다 .

다른 유닉스에서는 상황이 다를 수 있습니다. ps명령은 모든 곳에서 작동하며, /proc운영 체제에 따라 다릅니다. AIX에 예를 들어 전혀 없다 cmdline에서 /proc.


이것은 트릭을 할 것입니다 :

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

xargs가 없으면 인수 사이에 공백이 없습니다. 인수가 NUL로 변환 되었기 때문입니다.


전체 명령 줄

Linux & Unix System의 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

리눅스

cat /proc/<pid>/cmdline

프로세스의 명령 줄 (args 포함)이지만 모든 공백이 NUL 문자로 변경되었습니다.


(전체 명령 행) 및 (자세한 설명) pgrep함께 사용할 수 있습니다 .-f-l

pgrep -l -f PatternOfProcess

이 방법은 다른 응답과 결정적인 차이가 있습니다. CygWin 에서 작동 하므로 Windows에서 실행되는 모든 프로세스의 전체 명령 줄을 얻는 데 사용할 수 있습니다 ( 상승 / 관리 프로세스에 대한 데이터를 원하는 경우 상승으로 실행 ) . 예를 들어 , Windows에서이 작업을 수행하는 다른 방법이 더 어색 합니다.
또한 내 테스트에서 pgrep 방식은 CygWin의 python 내에서 실행되는 스크립트 의 전체 경로를 얻는 유일한 시스템 이었습니다 .


/proc/PID/cmdlineLinux에서 공백 으로 인쇄 하는 또 다른 변형은 다음 과 같습니다.

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

이런 식으로 NULL 문자를 그대로 cat인쇄 한 다음 ;를 사용하여 공백으로 대체합니다 . 줄 바꿈을 인쇄합니다.^@sedecho


간단하게 사용할 수 있습니다 :

ps -o args= -f -p ProcessPid

스트림을 편집하기 위해 여러 명령을 사용하는 대신 하나만 사용하십시오. tr은 한 문자를 다른 문자로 변환합니다.

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

위의 모든 텍스트 변환 방법 외에도 단순히 '문자열'을 사용하면 기본적으로 별도의 줄에 출력됩니다. 추가 혜택으로 터미널을 뒤섞을 수있는 문자가 표시되지 않을 수도 있습니다.

하나의 명령으로 두 출력 :

문자열 / proc // cmdline / proc // environ

진짜 질문은 ... cmdline이 실행 된 실제 명령 대신 변경된 텍스트를 포함하도록 변경된 Linux 프로세스의 실제 명령 줄을 보는 방법이 있습니까?


Solaris에서

     ps -eo pid,comm

유닉스 계열 시스템에서 비슷한 것을 사용할 수 있습니다.


Linux에서 bash를 사용하면 인용 된 인수로 출력하여 명령을 편집하고 다시 실행할 수 있습니다.

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

Solaris에서 bash (3.2.51 (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

리눅스 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

Solaris의 pargs 와 유사하게 가능한 오래 사용할 수있는 제한이 무엇인지 알고 싶다면 Linux 및 OSX에서 사용할 수 있습니다.

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

ps -n리눅스 터미널에서 시도하십시오 . 이것은 보여줄 것이다 :

1. 모든 프로세스 RUNNING , 명령 줄 및 PID

  1. 프로그램이 프로세스를 시작합니다.

나중에 당신은 죽일 프로세스를 알게 될 것입니다

참고 : https://stackoverflow.com/questions/821837/how-to-get-the-command-line-args-passed-to-a-running-process-on-unix-linux-syste

반응형