유닉스 / 리눅스 시스템에서 실행중인 프로세스로 커맨드 라인 인수를 얻는 방법?
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/cmdline
Linux에서 공백 으로 인쇄 하는 또 다른 변형은 다음 과 같습니다.
cat -v /proc/PID/cmdline | sed 's/\^@/\ /g' && echo
이런 식으로 NULL 문자를 그대로 cat
인쇄 한 다음 ;를 사용하여 공백으로 대체합니다 . 줄 바꿈을 인쇄합니다.^@
sed
echo
간단하게 사용할 수 있습니다 :
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
- 프로그램이 프로세스를 시작합니다.
나중에 당신은 죽일 프로세스를 알게 될 것입니다
'Programing' 카테고리의 다른 글
도메인 기반 디자인이란 무엇입니까? (0) | 2020.05.17 |
---|---|
JDBC 및 MySQL로 "통신 링크 실패"해결 (0) | 2020.05.16 |
Java : System.exit ()를 호출하는 메소드를 테스트하는 방법? (0) | 2020.05.16 |
두 세트의 교집합을 계산하는 방법은 무엇입니까? (0) | 2020.05.16 |
static_cast <>와 C 스타일 캐스팅의 차이점은 무엇입니까? (0) | 2020.05.16 |