Computer Science/운영체제

01 | Introduction to Operating Systems

lucid_07 2023. 9. 25. 15:01
반응형

운영체제 (이화여자대학교 반효경 교수)

Operating System

컴퓨터 하드웨어 바로 위에 설치되어 사용자 및 다른 모든 소프트웨어와 하드웨어를 연결하는 소프트웨어 계층

- 협의의 운영체제: 운영체제 핵심 부분으로 메모리에 상주하는 부분, 즉 커널

- 광의의 운영체제: 커널 뿐 아니라 각종 주변 시스템 유틸리티 포함

 

목적

자원을 효율적으로 관리🌟

  • 프로세서, 기억장치, 입출력 장치 등의 효율적 관리: 형평성 있는 자원 분배, 주어진 자원 내에서 최대의 성능 내도록(효율성)
  • 사용자 및 운영체제 자신의 보호
  • 프로세서, 파일, 메시지 등 관리

컴퓨터 시스템을 편리하게 사용할 수 있는 환경 제공

  • 동시 사용자/프로그램들이 각각 독자적 컴퓨터에서 수행되는 것 같은 환상을 제공: 추상화
  • 하드웨어를 직접 다루는 복잡한 부분을 운영체제가 담당

분류

동시 작업 가능 여부

  • 단일 작업(Single Tasking): 한 번에 하나의 작업만 처리 | MS-DOS
  • 다중 작업(Multi Tasking): 동시에 두 개 이상의 작업 처리 | UNIX, MS Windows

사용자 수

  • 단일 사용자(Single User): MS-DOS, MS-Windows
  • 다중 사용자(Multi User): UNIX, NT server

처리 방식

  • 일괄 처리(Batch Processing)
    • 작업 요청을 일정량 모아서 한꺼번에 처리
    • 작업이 완전 종료될 때까지 기다려야 함
    • 초기 Punch Card 처리 시스템
  • 시분할(Time Sharing) 😜컴퓨터 유저가 주로 사용하는 시스템: 우리의 메인 주제😜
    • 여러 작업을 수행할 때 컴퓨터 처리 능력을 일정한 시간 단위로 분할하여 사용
    • 사람이 느끼기에 빠른 처리속도를 가지며, 정해진 자원을 최대한 사용하는 것이 목적. 정해진 시간을 지켜주는 것은 아님
    • 일괄 처리 시스템에 비해 짧은 응답 시간을 가짐
    • Interactive
    • 다만, 최근 실시간성을 필요로하는 수요가 늘고있기 때문에(예: 스마트폰의 각종 기능들), 이런 애플리케이션을 범용 OS에서 어떻게 지원해야 하는가에 대한 이슈가 발생하고 있음
  • 실시간(Realtime OS)
    • 정해진 시간 안에 어떠한 일이 반드시 종료됨이 보장되어야 하는 실시간 시스템을 위한 OS
    • 원자로, 공장, 미사일, 반도체 장비, 로보트 제어 등
    • 확장 개념:
      • Hard realtime system(경성 실시간 시스템) : 반도체 공정 등
      • Soft realtime system(연성 실시간 시스템) : 영상 처리 작업 등

용어

Multitasking

Multiprogramming

Time sharing

Multiprocess

  • 여러 작업을 동시에 수행하는 것을 표현하는 용어들이나,
  • Multiprogramming은 여러 프로그램이 메모리에 올라가 있는 것을 강조한다.
  • Time Sharing은 CPU의 시간을 분할하여 나누어 쓴다는 의미를 강조한다.

* Multiprocessor를 사용한 병렬처리: 고성능 컴퓨팅(HPC)

종류

UNIX

어셈블리어에서 벗어나 운영체제를 위한 언어 시작됨: C
높은 이식성
소스 코드 공개
프로그램 개발에 용이
복잡한 시스템에 맞게 확장 용이
최소한의 커널 구조
다양한 버전:
- System V, FreeBSD, Solaris, SunOs
- Linux: 서버 운영체제에서 개인 PC를 위한 운영체제로 변신

MS-DOS

단일 작업용 운영체제로 출발(매우 작은 메모리 크기: 주기억장치 640 KB): 하드웨어의 발전을 생각하지 않음
옛날 기능 지원하면서 새로운 기능들을 추가하다보니 복잡하고 누더기 같은 시스템이 되어버림

Windows

GUI
Plug and Play
불안정성(초기)
풍부한 지원 소프트웨어

Mac, 기타 Handheld Device위한 운영체제: PalmOS, TinyOS, ...

구조

CPU 스케줄링

  • Disk: 메모리에 비해 60~100만배 느림, 메모리: CPU에 비해 수백배 느림 => 자원 활용 최대화 필요
  • 단순히 1/n하는 것은 문제를 해결하지 못함

메모리 관리

  • 메모리 공간은 한정, 여러 프로그램을 실행하고자 함.
  • 프로그램이 너무 많아 메모리를 조금 가지고 있다면 전체 시스템의 실행이 원활하지 못함. 원활히 실행되기 위한 최소한은 확보: Working Set 모델
  • 다시 사용할 가능성이 높은 것들을 메모리에 두어야 함: 미래는 어떻게 예측? => 과거 내역을 통해 자주 사용한 경우 메모리에 둠

파일 관리

  • 연속적으로? 조각으로? 디스크 특성에 맞게 관리하는 것이 필요
  • 디스크의 헤드를 가지고 읽고 쓰기 때문에 이에 맞게 순서를 바꾸어 디스크 헤드의 이동을 줄여주는 방법으로 효율화 해야함

입출력 관리: 인터럽트에 기반

  • I/O 디바이스의 관리
  • CPU보다 느리기 때문에 속도 차에 의한 차이를 운영체제가 담당함

 

반응형

'Computer Science > 운영체제' 카테고리의 다른 글

02 | System Structure & Program Execution - 1  (0) 2023.09.27