호기심 많은 개발자 🚀
프로세스란? 본문
Program 이란 "어떤 작업을 위해 실행되는 파일" 이다.
그리고 Process 란 Program이 "메모리에 올라와 실행되고 있는 프로그램의 인스턴스" 이다.
프로그램이 메모리에 할당되어 프로세스가 되고나면 프로세스 아이디인 PID를 할당 받게 된다.
PID를 이용해서 해당 프로세스만 종료하는 업무를 할 수 도 있다.
[root@peterdev dev]# kill -l
1) SIGHUP 2) SIGINT 3) SIGQUIT 4) SIGILL 5) SIGTRAP 6) SIGABRT 7) SIGBUS 8) SIGFPE 9) SIGKILL 10) SIGUSR1 11) SIGSEGV 12) SIGUSR2 13) SIGPIPE 14) SIGALRM 15) SIGTERM 16) SIGSTKFLT 17) SIGCHLD 18) SIGCONT 19) SIGSTOP 20) SIGTSTP 21) SIGTTIN 22) SIGTTOU 23) SIGURG 24) SIGXCPU 25) SIGXFSZ 26) SIGVTALRM 27) SIGPROF 28) SIGWINCH 29) SIGIO 30) SIGPWR 31) SIGSYS 34) SIGRTMIN 35) SIGRTMIN+1 36) SIGRTMIN+2 37) SIGRTMIN+3 38) SIGRTMIN+4 39) SIGRTMIN+5 40) SIGRTMIN+6 41) SIGRTMIN+7 42) SIGRTMIN+8 43) SIGRTMIN+9 44) SIGRTMIN+10 45) SIGRTMIN+11 46) SIGRTMIN+12 47) SIGRTMIN+13 48) SIGRTMIN+14 49) SIGRTMIN+15 50) SIGRTMAX-14 51) SIGRTMAX-13 52) SIGRTMAX-12 53) SIGRTMAX-11 54) SIGRTMAX-10 55) SIGRTMAX-9 56) SIGRTMAX-8 57) SIGRTMAX-7 58) SIGRTMAX-6 59) SIGRTMAX-5 60) SIGRTMAX-4 61) SIGRTMAX-3 62) SIGRTMAX-2 63) SIGRTMAX-1 64) SIGRTMAX
프로세스는 각각 독립된 메모리 영역(Code, Data, Stack, Heap의 구조)을 할당받는다.
기본적으로 프로세스당 최소 1개의 스레드(메인 스레드)를 가지고 있다.
스레드란 "프로세스가 할당받은 자원의 단위를 이야기 하며 , 프로세스 내에서 각각 Stack만 따로 할당받고 Code, Data, Heap 영역은 공유한다."
멀티 프로세싱이란 "하나의 응용프로그램을 여러 개의 프로세스로 구성하여 각 프로세스가 하나의 작업(태스크)을 처리하도록 하는 것이다." 멀티 프로세싱을 하면 프로세스간의 통신을 하며 업무를 처리해야 되기 때문에 오버 헤드가 많이 일어난다.
* * 하나의 프로세스가 다른 프로세스의 자원에 접근하려면 프로세스 간의 통신 필요 Ex. 메일 슬롯, 파이프, 소켓, 시그널, 공유 메모리 * *
오버헤드 "오버헤드(overhead)는 어떤 처리를 하기 위해 들어가는 간접적인 처리 시간 및 메모리등을 말합니다."
EX ] 기존 10초 걸리는 기능이 간접적인 원인 (프로세스 간의 통신 등) 으로 20초걸린다면 오버헤드는 10초가 되는것
"때문에 멀티 프로세스 보다는 Stack 이 외의 공간을 공유하는 멀티 쓰레드가 조금 더 효율적이다."
'OS > Process' 카테고리의 다른 글
😱 좀비 프로세스 ( Zombie Process ) 😱 (0) | 2022.05.02 |
---|---|
스케줄링 & 스케줄링 알고리즘(Scheduling Algorithm) (0) | 2022.04.10 |
HRN (Highest Response Ratio Next) 스케줄링 알고리즘 (0) | 2022.04.09 |
SJF (Shortest Job First) 스케줄링 알고리즘 (0) | 2022.04.09 |