운영체제란 무엇인가?

1. 운영체제(Operating System, OS)란 무엇인가?

  • 컴퓨터 하드웨어 바로 위에 설치되어, 소프트웨어와 사용자가 하드웨어 사이를 연결하는 소프트웨어 계층.
  • 좁은 의미의 운영체제 (커널) : 메모리에 상주하여 하드웨어의 자원을 배분하는 역할
  • 넓은 의미의 운영체제 (MS windows, Unix) : 커널과 그 외 다양한 소프트웨어.

2. 운영체제(커널)의 목표

  • 컴퓨터 시스템의 자원을 효율적으로 관리
  • CPU와 메모리, 입출력 장치의 자원을 각 사용자(각 가상머신)와 각 프로그램에 적절하게 배분하는 역할

3. 운영체제의 분류

3.1. 동시 작업 가능 여부

1) 단일 작업 (single tasking)

  • 한 번에 단 하나의 작업만 처리
  • MS-DOS
  • 작업만을 필요로 하는 현대의 특정 기기

2) 다중 작업 (multi tasking)

  • 한 번에 다양한 작업을 처리
  • MS windwos, Unix 등

3.2 사용자의 수

1) 단일 사용자(single user)

  • 단일한 사용자를 위한 시스템
  • MS-DOS, windows 등

2) 다중 사용자(multi user)

  • 다양한 사람이 하나의 시스템에 접근하여 작동
  • 단일 사용자를 위한 소프트웨어라 하더라도 서버를 구축하여 다중 사용자가 접근할 수 있도록 할 수 있음. window의 경우 로그인을 달리하여 하나의 컴퓨터에 다중 사용자가 사용 할 수 있음.

3.3 처리 방식

1) 일괄처리(batch processing)

  • 작업한 요청을 일정량 모아서 한번에 처리.
  • 초기의 Punch Card 시스템 (현재 사용하지 않음)
  • punch card의 경우 성적처리 시스템과 유사. OMR 카드의 결과값을 바로 응시자에게 답변하지 않음. 일괄적으로 OMR카드를 수거하여 컴퓨터가 그 값을 처리하고 일괄적으로 응시자에게 전달. 코딩한 punch card를 전산실이 모아서 일괄적으로 컴파일을 하는 방식.

2) 시분할(time sharing)

  • 자원(cpu 등)을 여러 사용자(혹은 작업)가 시간 단위로 공유/분할하여 사용.
  • 사용자의 입장에서는 자신의 입력 값을 즉각적으로 응답 받기 때문에 상호작용적임(interactive). 응답 시간이 일괄처리에 비하여 매우 짧음.
  • 결과 값 도출에 대한 제한 시간(deadline)이 존재하지 않음.

3) 실시간(Realtime OS)

  • 결과 값이 도출되어야 하는 제한 시간(deadline)이 존재하며 그 시간을 운영체제는 반드시 보장해야 함.
  • 미사일 / 원자로 / 반도체 등 엄격한 제어가 필요한 경우 사용.
  • Hard Realtime System : 매우 엄격한 실시간 운영체제. 시간을 보장받지 못하면 큰 문제가 발생할 수 있음.
  • Soft Realtime System : 제한 시간이 존재하나, 큰 문제가 발생하지고 불편함. 영상의 디코딩의 경우 1초에 24장의 이미지가 출력되도록 설계되었지만, 성능 상 문제로 이미지가 15장이 출력되더라도 치명적인 문제가 아님.

4. 운영 체제의 구조

  • 운영 체제는 cpu/메모리/외장메모리/입출력장치(I/O device)의 자원을 어떻게 효율적으로 분배하느냐가 가장 큰 쟁점.
  • 은행에서 단일한 상담사(단일 cpu)가 고객들을 응대하는 것과 유사. 은행 업무를 고객이 온 순서대로 처리를 하는 것이 공정할 수 있다. 하지만 첫 번째 손님이 100분의 시간을 사용하고 그 뒤의 고객이 1분 밖에 업무를 하지 않는다고 가정하면, 전체 고객의 입장에서는 매우 비효율적일 수 있음. 자원의 효율적인 배분을 스케쥴링이라 함.

1) cpu

  • 다른 장치에 비하여 매우 빠른 cpu의 자원을 효율적으로 사용하기 위한 루틴.
  • 여러 프로세스가 cpu를 공유하여 효과적으로 처리하기 위한 운영체제의 기능.

2) 메모리

  • 한정된 메모리를 효율적으로 사용하기 위한 기능.
  • 필요한 메모리를 외장 메모리로부터 불러오고, 더 이상 필요 없는 메모리를 삭제하는 기능.
  • 작업을 필요로 하는 것을 예측하여 디스크로부터 메모리에 로딩해야 cpu의 성능을 최대한으로 사용할 수 있음. 사용의 횟수, 기간 등 과거의 기록을 통해 미래의 사용을 예측하여 메모리를 미리 로딩함.

3) I/O 디바이스

  • 입출력장치의 사용을 효율적으로 하기 위한 기능.
  • 디스크의 경우 헤더를 통해 저장된 데이타를 불러옴. 디스크가 요청된 순서대로 해당 값을 불러오기 보다, 헤더의 이동 경로에 따라 값을 불러오는 것이 더 효과적일 수 있음. (엘레베이터에서 100층 1층 99층 2층을 눌렀다고 하여, 그 순서대로 엘레베이터가 이동하는 것이 아닌, 1층 - 2층 - 99층 - 100층을 이동하는 것과 같음)

4) 기타

  • 프로세스 관리, 시스템 보호, 네트워킹 등.

5. 기타 용어 비교

  • Multitasking : 다중 작업 -> Multiprogramming : 메모리에 다중 프로그램이 로딩 되어 있음. -> Time sharing : CPU를 시간을 분할하여 나누어 씀.

  • multiprocess : 하나의 컴퓨터에 다중 CPU가 있음.

비전공자로서 운영체제에 대한 지식이 많이 부족함을 느끼며 학습 중에 있습니다. 학습 자료의 선정은 블로그(https://covenant.tistory.com/100)를 참고하였습니다. 그리고 이화여대 반효경 교수의 영상강의(http://www.kocw.net/home/search/kemView.do?kemId=1046323)를 주요 자료로 하여 공부 중에 있습니다.