8. Process Management 1 & 9. Process Management 2

2022. 3. 14. 18:14· CS/OS
  • 프로세스 생성: 부모 프로세스가 자식 프로세스 생성 -> 트리(계층 구조) 형성
    • 프로세스는 자원을 필요로 함 (OS로부터 or 부모와 공유)
    • 자원의 공유
      • Copy-on-write(COW): write하기 전까지는 부모와 자원을 공유하다가 이후 copy
        • write하게 되면 본래의 내용이 바뀌게 됨
      • 부모와 자식이 모든 자원을 공유하는 모델
      • 일부를 공유하는 모델
      • 전혀 공유하지 않는 모델
    • 수행(execution)
      • 부모 자식이 공존하며 수행되는 모델
      • 자식이 종료될 때까지 부모가 기다리는 모델
    • 주소 공간
      • 자식은 부모의 공간 복사 (binary and OS data)
      • 자식은 그 공간에 새로운 프로그램을 올림
      • 유닉스의 예
        • fork() 시스템 콜이 새로운 프로세스 생성
        • 이후 exec() 시스템 콜을 통해 새로운 프로그램을 메모리에 올림
        • 복사하지 않고 exec()하면 그냥 나 자신이 새로운 프로그램을 덮힌다
  • 프로세스 종료 (자발적 or 비자발적 -> 자식의 입장에서)
    • 프로세스가 마지막 명령을 수행한 후 운영체제에게 이를 알려줌 (exit)
      • 자식이 부모에게 output data를 보냄 (via wait)
      • 프로세스의 각종 자원들이 OS에 반납됨
    • 부모 프로세스가 자식의 수행을 종료시킴 (abort)
      • 자식이 할당 자원의 한계치를 넘어섬
      • 자식에게 할당된 태스크가 더 이상 필요하지 않음
      • 부모가 종료(exit)하는 경우: 단계적인 종료 -> 모든 자식이 먼저 종료되게 하고 종료됨
  • fork() 시스템 콜

  • 부모가 fork() 실행하면 동일한 프로그램(자식)이 복사가 되며, 그 자식은 fork() 이후부터 실행하고 pid = 0이 된다

 

  • exec() 시스템 콜

  • 자식 프로그램이 exec()을 통해 date라는 프로그램으로 덮이는 예시이다
  • 이후 date 프로그램의 코드를 모두 수행하고 나면 종료된다 (다시 exec() 하기 전의 코드로 복귀 불가)

 

  • wait() 시스템 콜

자식이 종료될 때 까지 부모가 기다리는 모델

 

  • exit() 시스템 콜
    • 프로세스의 종료
      • 자발적 종료: 마지막 statement 수행 후 exit() 시스템 콜을 통해
        • 프로그램에 명시적으로 적어주지 않아도 main 함수가 리턴되는 위치에 컴파일러가 넣어줌
      • 비자발적 종료
        • 부모 프로세스가 자식 프로세스를 강제 종료시킴
          • 자식 프로세스가 한계치를 넘어서는 자원 요청
          • 자식에게 할당된 태스크가 더 이상 필요하지 않음
          • 자식들이 모두 종료 되어야 부모 프로세스가 종료될 수 있음
        • 키보드로 kill, break 등을 입력한 경우
  • 프로세스 간 협력

  • message passing에서도 메시지를 받을 프로세스를 명시적으로 나타내는지 여부에 따라 두가지로 나뉜다
  • shared memory에서 두 프로세스는 서로 신뢰가 높은 상태여야 한다

 

출처: https://core.ewha.ac.kr/publicview/C0101020140321144554159683?vmode=f 

https://core.ewha.ac.kr/publicview/C0101020140325134428879622?vmode=f 

저작자표시 비영리 동일조건 (새창열림)

'CS > OS' 카테고리의 다른 글

11. CPU Scheduling 2  (0) 2022.03.23
10. CPU Scheduling 1  (0) 2022.03.23
6. Process2 & 7. Process3  (0) 2022.03.08
5. Process1  (0) 2022.03.07
4. System Structure & Program Execution 2  (0) 2022.03.04
'CS/OS' 카테고리의 다른 글
  • 11. CPU Scheduling 2
  • 10. CPU Scheduling 1
  • 6. Process2 & 7. Process3
  • 5. Process1
hjkim0502
hjkim0502
개발 일지
hjkim0502
CODELOG
hjkim0502
글쓰기
전체
오늘
어제
  • Codelog (168)
    • course (61)
      • nomadcoder (5)
      • spartacoding (22)
      • inflearn (27)
      • 생활코딩 (7)
    • CS (68)
      • algorithm & data structure (34)
      • OS (26)
      • CA (0)
      • DB (8)
      • Network (0)
    • 코딩테스트 (2)
    • 이노베이션 캠프 (37)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • JS
  • til
  • QueryDSL
  • SQL
  • Python
  • Memory
  • 자바
  • 파이썬
  • cs
  • 프로그래머스
  • 생활코딩
  • db
  • 인프런
  • 카카오
  • html
  • JPQL
  • ajax
  • spring
  • API
  • leetcode
  • OS
  • JPA
  • inflearn
  • 레벨2
  • MongoDB
  • dfs
  • Java
  • css
  • ORM
  • KOCW

최근 댓글

hELLO · Designed By 정상우.v4.2.2
hjkim0502
8. Process Management 1 & 9. Process Management 2
상단으로

티스토리툴바

개인정보

  • 티스토리 홈
  • 포럼
  • 로그인

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.