Computer Security

#39 기본 시그널 처리 (실습) 본문

리눅스 시스템 프로그래밍

#39 기본 시그널 처리 (실습)

쿠리 Kuri 2022. 10. 14. 18:30
반응형

시그널의 동작에 대해 프로그램 실습을 해보자.

 

 

 

 


1. 기본 뼈대를 만든다.

main

 

 

 

 

 

 


2. 시그널을 받기 위해, 기다려야한다. while 문을 이용하자.

while

gcc 컴파일 한 뒤, ./signal로 실행 시켜보자.

 

현재 기다리는 중(무한루프)이다.

 

 

 

 

 

 


3.  ps 명령어를 통해 signal이 어떻게 실행중인지 살펴보자.

ps

2728 번으로 실행된 것을 알 수 있다.

 

 

 

 

 

 


4. 2728  pid 로 시그널을 보내보자. kill 이라는 명령어로 전달해주자.

kill

다른 터미널에서 kill -TERM 명령어로 종료신호를 보내니 아래와 같이 바로 실행이 종료 된 것을 알 수 있다.

 

종료

 

kill -TERM pid 대신  kill -TERM 'pidof signal' 이라는 명령어를 사용하면, 그때그때 바뀌는 pid를 일일히 넣어주지 않아도 signal이라는 프로세스의 pid가 알아서 넣어진다.

 

killall -TERM signal 명령어를 사용하면 signal이라는 이름을 가지는 모든 프로세스에게 전달해준다.

 

 

 

 

 

 


5. sig term 메세지를 받았을 때, 종료되지 않고 지정한 signal handler를 실행할 수 있게 코드를 짜보자.

sigterm

#include <signal.h>


typedef void (*sighandler_t) (int);
sighandler_t signal (int signum, sighandler_t handler);

signal(SIGTERM, sigterm_handler) : SIGTERM 신호를 받으면 sigterm_handler라는 함수를 실행한다.

 

 

 

 

 

 


6. 다시 컴파일 한 뒤, 똑같이 SIGTERM 신호를 보내보자.

./signal

똑같이 신호를 보냈을 때, 이번엔 종료가 되지 않고, sigterm_handler 함수안의 있는 printf()를 출력 한 것을 알 수 있다.

 

 

 

 

 

 


7. sigprocmask API를 이용해서 해당 시그널을 blocking 해보자.

signal.c

#include <signal.h>

int sigprocmask(int how, const sigset_t *set, sigset_t *oldset);

1. sigemptyset 으로 set을 초기화 해준다.

2. sigaddset 으로 SIGINT를 추가해준다.

3. sigprocmask로 blocking 해준다.

 

SIGINT 에 대해서는 blocking 하고, SIGTERM에 대해서는 sigterm_handler로 가게끔 코드를 작성했다.

 

 

 

 

 

 

 


8. gcc 명령어로 컴파일 한 뒤, SIGTERM과 SIGINT를 차례로 보내보자.

 

SIGTERM)

SIGTERM

sigterm_handler로 가서 printf를 출력한 것을 알 수 있다.

 

 

SIGINT)

SIGINT

아무런 변화가 없다. (blocking 상태)

 

SIGKILL)

SIGKILL

killall -s KILL signal 명령어를 이용해서 죽여주자.

 

 

 

반응형
Comments