Skip to content

Strace - 시스템콜과 신호 추적

조회 수 6042 추천 수 0 2014.02.25 11:10:10
strace는 system-call Tracer를 의미하는 말로, strace에 의해 추적되는 프로세스의
시스템콜, 신호를 모두 화면에 출력한다.
(시스템콜 ex : read,write,exit,lstat,ipc,fork.... 대부분 표준 C 라이브러리 내에 함수로 존재)

strace 프로그램은 ptrace라는 시스템콜을 사용하여 자식 프로세스가
어떤 시스템 콜을 호출하는지 감시하고, 호출하는 시스템 콜에 대해 화면에 출력한다.

:: 시스템콜 실패시 strace를 이용하면 어떤 시스템콜이 실패하였는지 쉽게 알아낼 수 있다.
:: 예외처리를 해준다면 더욱 쉽게 알아낼 수 있을 것이다.


일단 strace 유틸리티로 추적해볼 프로그램을 만들어보자.

/*
 *   gcc scall.c -o scall
 *   굵게 표시된 부분은 시스템콜을 의미
 *   아무 의미 없지만, 마구잡이로 시스템콜을 써먹은 예제입니다.
 */

#include<stdio.h>
#include<stdlib.h>
#include<fcntl.h>

int main(void){

    pid_t pid = fork();

    if(pid == 0)
        exit(0);

    int p[2];
    pipe(p);

    int a = open("/dev/null",O_RDONLY);
    int b = open("./diary",O_RDONLY);

    return 0;
}


strace.png



주황색으로 줄친부분 외에, 그 윗부분은 공유 라이브러리를 링크하는 부분으로,
동적 링크가 커널에게 요청한 시스템 콜로 신경쓸 필요 없다.



프로그래머가 입력한 시스템콜은 그 아래에 나타난다.

clone() :: fork()는 내부적으로 clone() 이라는 시스템콜을 호출한다.
SIGCHLD :: 자식 프로세스로부터 신호가 추적됨. (종료코드 0 :: exit(0) )
pipe() :: pipe() 시스템콜을 사용한것을 알 수 있다.
open("/dev/null",~~~~) :: /dev/null을 가리키는 파일 서술자의 값이 5임을 알 수 있다.
open("./diary",~~~) 뒷쪽에 No such file or directory 라는 글이 보이진 않지만,
strace를 통해 diary라는 파일을 open() 시스템콜로 찾는다는 것과,
그 파일이 존재하지 않음을 알 수 있다.




옵션/

-c :: time, second, usecs/call, calls, errors, syscall 들로 목록화하여 결과를 뽑아낸다.
-f :: fork로 생성된 자식프로세스의 시스템콜까지 추적한다.
-F :: vfork로 생성된 자식프로세스의 시스템콜까지 추적한다.
-p [pid] :: 프로세스를 지정하여 시스템콜을 추적한다.
-v :: 버젼, 환경, 상태 등을 포함하여 결과를 뽑아낸다.
-x :: ASCII 이 아닌 문자열을 16진수형태로 추가하여 결과를 출력한다.
-xx :: 모든 문자열을 16진수 형태로 출력

등등.. 이외엔 man page 참조.. 

참고문헌 : 유닉스 리눅스 프로그래밍

List of Articles
번호 제목 글쓴이 날짜 조회 수sort
367 linux daemon (리눅스 데몬 설명) ADMINPLAY 2014-02-26 647764
366 대용량 HDD 파티셔닝(Mass storage Partitioning) (GPT 파... ADMINPLAY 2010-04-14 73467
365 FFMPEG를 가장쉽게 설치하는 방법(ffmpeg-php 등) ADMINPLAY 2010-05-03 66240
364 rrdtool 컴파일시 에러 configure: error: Please fix the... ADMINPLAY 2009-08-08 64599
363 커널 2.6으로 업그레이드!「A to Z」 ADMINPLAY 2009-08-08 64244
362 e2fsck - 파일 시스템 복구 및 검사. - fsck file ADMINPLAY 2010-09-12 60903
361 배치파일을 이용한 백업방법 l2zeo 2010-03-31 59533
360 Maskrading ADMIN 2008-11-11 58615
359 시스템 백업과 응급 복구 ADMINPLAY 2009-05-11 58572
358 리눅스 전원부터 부팅이 되기까지의 과정이해 ADMIN 2008-11-11 57448
357 리눅스 디렉토리 구조와 파티션 관리의 기본 ADMINPLAY 2009-05-22 57401
356 hdparm 세부옵션 ADMINPLAY 2012-01-16 54964
355 CentOS 설치 - VMware 상에서 CentOS 설치하기 file l2zeo 2010-02-24 52101
354 Red Hat Linux 9 ADMINPLAY 2009-09-24 51551
353 Dell OMSA 설치 및 이용방법 ADMINPLAY 2014-08-13 49631
352 2TB이상의 Disk를 사용한 Raid6 구성 ADMINPLAY 2015-08-08 46039
351 sulinux 1.0. 서버 패키지 리스트 ADMINPLAY 2011-04-30 45478
350 ORA-01031: insufficient privileges 오류 ADMINPLAY 2010-02-24 41013
349 [APM] 리눅스에서 Apache, PHP, MySQL 등 제거 방법 ADMINPLAY 2009-06-29 39388
348 AIX 필수 명령어 ADMINPLAY 2009-12-10 39118

Copyright ADMINPLAY corp. All rights reserved.

abcXYZ, 세종대왕,1234

abcXYZ, 세종대왕,1234