Microsoft MVP성태의 닷넷 이야기
글쓴 사람
정성태 (techsharer at outlook.com)
홈페이지
첨부 파일
 

리눅스 - 실행 중인 다른 프로그램의 출력을 확인하는 방법

간단하게 다음과 같이 파이썬 예제를 작성해 볼까요?

import os
import sys
import time

pid = os.getpid()


def log(text):
    current_time = time.localtime(time.time())
    text = time.strftime('%Y/%m/%d %H:%M:%S', current_time)

    output = "[" + str(pid) + "] " + text + "\n"
    sys.stdout.write(output)


while True:
    log('test')
    time.sleep(1)

실행하면 화면에는 당연히 로그가 찍힐 텐데요, 저 출력을 shell에서도 확인할 수 있을까요? 관련해서 검색해 보면 다음의 방법이 나옵니다.

How to view the output of a running process in another bash session?
; https://unix.stackexchange.com/questions/58550/how-to-view-the-output-of-a-running-process-in-another-bash-session

그러니까, strace로 실행 중인 프로세스의 API 호출을 확인할 수 있는 것입니다.

$ strace -p2490 -s9999 -e write
...[생략]...
write(1, "[2490] 2021/09/10 14:34:22\n", 27) = 27
write(1, "[2490] 2021/09/10 14:34:23\n", 27) = 27

하지만, strace가 API 수준이다 보니 좀 출력이 거칠어지는 경우가 있습니다. 가령 다음과 같은 식으로 파이썬 코드를 바꾸면,

print(f"[{pid}] {text}")

하나의 print에 대해 이번엔 개행 문자가 분리돼 나옵니다.

$ strace -p2508 -s9999 -e write
...[생략]...
write(1, "[2508] 2021/09/10 14:36:00", 26) = 26
write(1, "\n", 1)                       = 1

간단한 출력이라 상관없지만 복잡하게 되면, print 하나 당 여러 줄의 write 구문이 찍혀 다소 어지럽습니다.

반면 tail을 이용하는 방법도 있다고 하는데요,

[형식]
tail -f /proc/<pid>/fd/1
    0 is standard input, 
    1 standard output, 
    2 standard error,

예) 
tail -f /proc /2926/fd/1

실제로 해보면, 출력은 되는데,

$ tail -f /proc/2926/fd/1
[2926] 2021/09/10 15:43:18
[2926] 2021/09/10 15:43:19
[2926] 2021/09/10 15:43:20
[2926] 2021/09/10 15:43:21
[2926] 2021/09/10 15:43:22
[2926] 2021/09/10 15:43:23
[2926] 2021/09/10 15:43:24
[2926] 2021/09/10 15:43:25
[2926] 2021/09/10 15:43:26
[2926] 2021/09/10 15:43:27
...[약 5분 후쯤에 다시 출력]...
[2926] 2021/09/10 15:48:29
[2926] 2021/09/10 15:48:30
...[약 5분 후쯤에 다시 출력]...
[2926] 2021/09/10 15:53:32
[2926] 2021/09/10 15:53:33

출력에 버퍼링이 있는 듯합니다. 비록 버퍼링은 되지만 실시간 출력이 필요 없다면 strace보다는 깔끔하기 때문에 쓸 만할 것입니다.




[이 글에 대해서 여러분들과 의견을 공유하고 싶습니다. 틀리거나 미흡한 부분 또는 의문 사항이 있으시면 언제든 댓글 남겨주십시오.]







[최초 등록일: ]
[최종 수정일: 9/10/2021]

Creative Commons License
이 저작물은 크리에이티브 커먼즈 코리아 저작자표시-비영리-변경금지 2.0 대한민국 라이센스에 따라 이용하실 수 있습니다.
by SeongTae Jeong, mailto:techsharer at outlook.com

비밀번호

댓글 작성자
 




[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...
NoWriterDateCnt.TitleFile(s)
13953정성태6/16/202523스크립트: 78. 파이썬 - 소스 코드의 파일 경로를 지정한 모듈 로드
13952정성태6/15/2025323닷넷: 2336. C# - IValueTaskSource로 인해 주의가 필요한 ValueTask 호출파일 다운로드1
13951정성태6/15/2025291오류 유형: 964. Outlook - 일정이 "You cannot make changes to contents of this read-only folder." 오류 메시지로 삭제가 안 되는 경우
13950정성태6/12/20251137닷넷: 2335. C# - 간단하게 구현해 보는 IValueTaskSource 예제파일 다운로드1
13949정성태6/11/2025957오류 유형: 963. SignTool - "Error: SignerSign() failed." (-2146869243/0x80096005)
13948정성태6/10/2025626오류 유형: 962. 파이썬 - Linux 환경 + TCP 서버 소켓을 사용하는 프로세스 종료 후 재실행하는 경우 "OSError: [Errno 98] Address already in use" 오류 발생
13947정성태6/9/20251378개발 환경 구성: 750. 파이썬 - Azure App Service에 응용 프로그램 배포 후의 환경
13946정성태6/9/20251604개발 환경 구성: 749. 파이썬 - Azure App Service에 응용 프로그램 배포하기 전의 환경
13945정성태6/7/20251528오류 유형: 961. 파이썬 + conda - mysqlclient 사용 시 "NameError: name '_mysql' is not defined" 에러
13944정성태6/7/20255267오류 유형: 960. The trust relationship between this workstation and the primary domain failed. - 네 번째 이야기
13943정성태6/6/20251745개발 환경 구성: 748. Windows + Foundry Local - 로컬에서 AI 모델 활용
13942정성태6/5/20251409오류 유형: 959. winget 설치 시 "0x80d02002 : unknown error"
13941정성태6/2/20251343닷넷: 2334. C# - cpuid 명령어를 이용한 CPU 제조사 문자열 가져오기파일 다운로드1
13940정성태6/1/20251729C/C++: 188. C++의 32비트 + Release 어셈블리 코드를 .NET으로 포팅할 때 주의할 점파일 다운로드1
13939정성태5/29/20252110오류 유형: 958. NVIDIA Triton Inference Server - version `GLIBCXX_3.4.32' not found (required by /opt/tritonserver/backends/python/triton_python_backend_stub)
13938정성태5/29/20251635개발 환경 구성: 747. 파이썬 - WSL/docker에 구성한 Triton 예제 개발 환경
13937정성태5/24/20251523개발 환경 구성: 746. Windows + WSL2 환경에서 (tensorflow 등의) NVIDIA GPU 인식
13936정성태5/23/20251379개발 환경 구성: 745. Linux / WSL 환경에 Miniconda 설치하기
13935정성태5/20/20251326오류 유형: 957. 파이썬 - pip 사용 시 "ImportError: cannot import name 'html5lib' from 'pip._vendor'" 오류
13934정성태5/20/20251840스크립트: 77. 파이썬 - 'urllib.request' 모듈의 명시적/암시적 로딩 차이
13933정성태5/19/20251455오류 유형: 956. Visual Studio 2022가 17.12 버전부터 업데이트 되지 않는다면?
13932정성태5/18/20251700스크립트: 76. 파이썬 - Version 문자열 다루기(semver 패키지)
13931정성태5/17/20252002스크립트: 75. 파이썬 - Cython 기본 예제 및 컴파일
13930정성태5/17/20251697개발 환경 구성: 744. 파이썬 - Windows embeddable package 환경에서 외부 패키지 사용하는 방법(ex: UFO² 환경 구성)
13929정성태5/16/20251777오류 유형: 955. 파이썬 - "Windows embeddable package" REPL 환경에서 "NameError: name 'exit' is not defined"
[1]  2  3  4  5  6  7  8  9  10  11  12  13  14  15  ...