|
운영 체제(運營體制, Operating System, OS)
컴퓨터 시스템의 전반적인 동작을 제어하고 조정하는 시스템 프로그램들의 집합.
본문
운영체제라고도 한다. 이 프로그램들은 하드웨어와 응용프로그램간의 인터페이스 역할을 하면서
CPU, 주기억장치, 입출력장치 등의 컴퓨터 자원을 관리한다. 즉, 인간과 컴퓨터간의 상호작용을 제공함과
동시에 컴퓨터의 동작을 구동(booting)하고 작업의 순서를 정하며 입출력 연산을 제어한다.
또 프로그램의 실행을 제어하며 데이터와 파일의 저장을 관리하는 등의 기능을 한다.
현재와는 의미가 다르지만 최초의 운영체제는 IBM-701 컴퓨터의 사용을 위하여 제너널 모터스(General Motors;GM)
연구소에서 1950년 초반 처음 개발되었다. 그 후 1955년에는 IBM-704의 운영체제가 NAA(North American Aviation)와
GM의 합작으로 개발되었다. 1959년 노스아메리카 항공사에서 개발한 Fortran Ⅱ 모니터는 오퍼레이터의 개입을
최소화하여 컴퓨터 시스템 조작의 자동화를 목표로 한 최초의 현대적 의미의 운영체제이다.
또 저속의 주변 입출력장치 때문에 주컴퓨터의 이용효율이 저하하는 것을 피하기 위하여 위성 컴퓨터를 배치하여
주컴퓨터의 입출력은 고속의 자기 테이프 장치를 이용하도록 시스템을 구성하였다. 이들 시스템에서 입출력은
입출력제어 프로그램으로서 개발한 입출력제어 시스템(IOCS;input/output control system)이 쓰였다.
1964년 IBM사는 시스템/360을 발표하고, 1966년에는 OS/360 최초의 판이 사용 가능하였다. OS/360은
시스템/360 계열 전체에 이용하려 한 일괄처리용 운영체제로서 운영체제 개념의 명확화, 기능의 체계화가 이루어졌다.
그 이후 세그먼트 기법, 페이징에 의한 가상기억방식의 도입, 계층적 디렉터리를 갖는 파일링 시스템 등의 개념이
도입되면서 운영체제 개발이 급속히 진전되었다. 1980년대에는 개인용 컴퓨터가 보급되면서 개인용 컴퓨터
운영체제로 CP/M, MS-DOS, Windows 등이 개발되었으며, 슈퍼미니컴퓨터 ·워크스테이션용으로 이식성이
우수한 UNIX 시스템이 보급되었다. 또 VMS나 OS/2 등의 새로운 운영체제가 출현하였다.
운영 체제(한자: 運營體制, 문화어: 조작체계) 또는 오퍼레이팅 시스템(영어: Operating System, OS)
운영체제는 시스템 하드웨어를 관리할뿐 아니라 응용 소프트웨어를 실행하기 위하여 하드웨어 추상화 플랫폼과
공통 시스템 서비스를 제공하는 시스템 소프트웨어이다. 최근에는 가상화 기술의 발전에 힘입어 실제
하드웨어가 아닌 하이퍼바이저 위에서 실행되기도 한다. 입출력과 메모리 할당과 같은 하드웨어 기능의 경우
운영 체제는 응용 프로그램과 컴퓨터 하드웨어 사이의 중재 역할을 한다.
그러나 응용 프로그램 코드는 일반적으로 하드웨어에서 직접 실행된다.
운영 체제는 휴대 전화, 게임기에서부터 슈퍼 컴퓨터, 웹 서버에 이르기까지 컴퓨터를 포함하는 거의 모든
장치에서 볼 수 있다. 운영 체제는 한 면으로는 소비자를, 다른 한 면으로는 프로그램 개발자를 함께 하나의
시장으로 데려다 놓을 수 있는 양면 플랫폼이다. 현대의 PC 운영 체제에는 마이크로소프트 윈도,
맥 OS X, 리눅스가 있다. 이 밖에 BSD, 유닉스 등의 PC용 운영 체제도 존재한다.
운영 체제는 실행되는 응용 프로그램들이 메모리와 CPU, 입출력 장치 등의 자원들을 사용할 수 있도록 만들어 주고,
이들을 추상화하여 파일 시스템 등의 서비스를 제공한다. 또한 멀티태스킹을 지원하는 경우,
여러 개의 응용 프로그램을 실행하고 있는 동안, 운영 체제는 이러한 모든 프로세스들을 스케줄링하여 마치
그들이 동시에 수행되는 것처럼 보이는 효과를 낸다. 운영 체제는 컴퓨터 과학의 연구 분야이기도 하다.
종류
실시간 운영 체제
다중 사용자 운영 체제
단일 사용자 운영 체제
멀티태스킹 운영 체제
싱글태스킹 운영 체제
분산 운영 체제
임베디드 운영 체제
개요
초기의 컴퓨터들은 계산기처럼 일련의 단일 작업들을 수행하기 위하여 만들어졌다.
운영 체제는 1960년대 초까지만 하여도 현대의 운영 체제와 같이 더 복잡한 형태로 존재하지 않았다.
처리를 빠르게 하기 위하여 자동으로 다른 프로그램들을 연속으로 실행할 수 있는 기능과 같은
일부 운영 체제의 기능은 1950년대에 개발되었다.
하드웨어 기능에 런타임 라이브러리, 인터럽트, 병렬 처리가 추가되었다.
개인용 컴퓨터가 애플, 아타리, IBM, 아미가와 같은 기업 덕택에 1980년대에 유명해졌다.
이 업체들은 한때 메인프레임과 미니 컴퓨터에 널리 쓰였던 운영 체제 기능을 추가하였다.
나중에 그래픽 사용자 인터페이스와 같은 수많은 기능들이 개인용 컴퓨터 운영 체제를 위해 개별적으로 개발되었다.
운영 체제는 많은 부분을 이룬다. 가장 중요한 요소 가운데 하나가 커널인데, 커널은 일반인이
일반적으로 보지 못하는 낮은 수준의 프로세스를 제어한다. 얼마나 메모리를 읽고 쓸 것인지,
어느 프로세스를 실행할 것인지, 모니터, 키보드, 마우스와 같은 장치를 통해 어떠한 정보를 주고받을 것인지,
네트워크를 통해 받은 정보를 어떻게 해석할 것인지를 제어한다.
사용자 인터페이스는 컴퓨터 사용자가 직접 프로그램을 제어하고 사용할 수 있게 하는 운영 체제의 기능이다.
사용자 인터페이스는 아이콘과 바탕 화면을 지닌 그래픽이나 명령 줄을 지닌 문자를 이룰 수 있다.
이와 비슷한 기능으로 API가 있는데 이것은 응용 프로그램이 다른 프로그램과 상호 작용할 수 있게 하는
서비스와 코드 라이브러리가 한데 모여 있으며 운영 체제 그 자체라고 할 수도 있다.
운영 체제에 따라 이러한 구성 요소들 가운데 다수가 실질적인 부분으로 취급되지 않을 수도 있다.
이를테면 윈도는 사용자 인터페이스를 운영 체제의 일부로 여기는데 반해 수많은 버전의 리눅스는 그렇지 않다.
목적 : 운영 체제의 중요한 목적은 이를테면 다음과 같다.
사용자에게 컴퓨터의 프로그램을 쉽고 효율적으로 실행할 수 있는 환경을 제공한다.
컴퓨터 시스템 하드웨어 및 소프트웨어 자원을 여러 사용자 간에 효율적 할당, 관리, 보호하는 것
운영 체제는 제어 프로그램으로서 사용자 프로그램의 오류나 잘못된 자원 사용을 감시하는 것과
입출력 장치 등의 자원에 대한 연산과 제어를 관리한다.
시스템 구성
일반적인 응용 프로그램들을 제외한 컴퓨터 시스템은 개념적으로 세 개의 구성 요소로
구분하기도 한다. 그 세 부분은 운영 체제, 셸, 그리고 (낮은 수준의) 필수 유틸리티들이다.
셸은 사용자가 시스템을 운용할 수 있게끔 해주는 기본적인 응용 프로그램이다.
이런 셸의 행동들은 결국 운영 체제에 명령을 내리는 일이 된다. bash 등의 이러한 셸은 그러나 엄밀히
운영 체제의 일부가 아니며 운영 체제 입장에서는 셸이나 필수 유틸리티들이나 모두 응용 프로그램일뿐
구별하지 않는다. 다만 이러한 구분은 사용자의 입장에서 필수적인 응용 프로그램이라는 뜻이다.
하드웨어 ↔ 운영 체제 ↔ 셸 / 응용 프로그램 ↔ 사용자
역사 : 이 부분의 본문은 운영 체제의 역사입니다.
나사(NASA)가 달에 사람을 착륙시키는 데 도움을 준 컴퓨터를 포함하여
OS/360은 1966년부터 대부분의 IBM 메인프레임 컴퓨터에 쓰였다.
1950년대 초에 컴퓨터는 한 번에 하나의 프로그램만 실행할 수 있었다. 각 사용자는 컴퓨터만을
사용하여 예약된 시간에 천공 카드와 테이프의 프로그램과 데이터에 접근하여야 했다.
프로그램이 컴퓨터에 적재되면 컴퓨터는 프로그램이 끝나거나 충돌을 일으킬 때까지 계속 동작하였다.
토글 스위치와 패널 불빛을 이용하여 앞면 패널을 통해 프로그램을 디버깅할 수 있었다.
그 뒤에 나온 컴퓨터는 인간이 알아들을 수 있는 어셈블리어로부터의 기계어 발생이나 입출력과 같은
기능을 도와주기 위하여 사용자 프로그램을 연결해 놓은 소프트웨어 라이브러리와 함께 등장하였다.
이때가 바로 현대 운영 체제의 탄생 시기이다. 그러나 여전히 컴퓨터는 한 번에 하나의 일만 할 수 있었다.
메인프레임
1950년대를 통해 일괄 처리, 입출력 인터럽트, 버퍼링, 멀티태스킹, 스풀링, 런타임 라이브러리,
파일 정렬을 위한 프로그램을 포함한 수많은 주요 기능들이 운영 체제 분야에 포함되었다.
이러한 기능들은 프로그래머의 취향에 따라 응용 소프트웨어에 포함되어 있기도 했고 포함되지 않기도 했다.
1959년에 IBM 704, 709, 7090 메인프레임 컴퓨터를 위한 셰어 운영 체제(SHARE)가 통합 유틸리티로 출시되었다.
마이크로컴퓨터
PC-DOS는 명령 줄 인터페이스 기능을 제공하였던 초기의 개인용 컴퓨터 운영 체제였다.
최초의 마이크로컴퓨터는 메인프레임과 미니컴퓨터를 위해 개발해 둔 운영 체제에 대한 필요성도 그만한 용량도 없었다.
모니터스(Monitors)라는 이름의 매우 작은 운영 체제가 개발되었으며 롬에서 불러들였다.
눈에 띄는 초기의 디스크 기반 운영 체제로 CP/M이 있었는데 수많은 초기 마이크로컴퓨터에서 지원되었으며
IBM PC에 널리 쓰였던 MS-DOS(IBM 버전의 것은 IBM DOS, 곧 PC-DOS로 불렸다)와 매우 비슷하였다.
1980년대에 애플 컴퓨터사(지금의 애플사)가 애플 II 시리즈의 마이크로컴퓨터를 버리고,
혁신적인 그래픽 사용자 인터페이스를 맥 OS 운영 체제에 갖춘 애플 매킨토시 컴퓨터를 도입하였다.
32비트 아키텍처에 페이징 기능을 갖춘 인텔 80386 CPU 칩이 도입되면서 개인용 컴퓨터가
초기의 미니컴퓨터와 메인프레임 컴퓨터에서 실행할 수 있었던 멀티태스킹 운영 체제를 사용할 수 있게 되었다.
마이크로소프트는 DEC용 VMS 운영 체제를 개발하였던 데이비드 커틀러를 해고함으로써
이러한 진행에 응하였다. 그는 마이크로소프트의 운영 체제 기반을 다룰 윈도 NT 운영 체제 개발을 이끌었다.
애플의 공동 창립자 스티브 잡스는 NeXT 컴퓨터사를 차렸고 유닉스 계열 넥스트스텝 운영 체제를 개발하였다.
넥스트스텝은 훗날 애플에 인수되었으며 FreeBSD 코드가 맥 OS X의 중심이 되었다.
프로그래머 리처드 스톨만이 사유 유닉스 운영 체제를 대체하는 자유 소프트웨어를 목표로
GNU 프로젝트를 시작하였다. 이 프로젝트가 유닉스 여러 곳의 기능을 복제하는 데 큰 성공을 이루자
GNU 허드 커널 개발은 비생산적인 것으로 입증되었다. 1991년 핀란드 컴퓨터 과학부 학생인
리누스 토르발스는 최초의 리눅스 커널 버전을 출시하였다.
곧 GNU 유저랜드와 시스템 소프트웨어에 병합되면서 컴퓨터 운영 체제를 이루게 되었다.
BSD는 유닉스 계열로서 1970년대에 시작하여 수많은 미니컴퓨터에 포팅되었으며
마침내 FreeBSD, NetBSD, OpenBSD와 같이 개인용 컴퓨터에도 쓰이게 되었다.
운영 체제의 예: 이 부분의 본문은 운영 체제의 목록입니다.
유닉스 및 유닉스 계열 운영 체제 : 이 부분의 본문은 유닉스, 유닉스 계열입니다.
유닉스 계열의 역사
켄 톰프슨은 BCPL에 기반을 둔 B를 작성하였다. 이것으로 말미암아 그는 유닉스를 작성하기도 하였는데,
이는 멀틱스 프로젝트에서의 경험을 바탕으로 한다. C는 B를 대체하였으며 유닉스는 현대의 모든
운영 체제에 영향을 미쳤던 크고 복잡한 계열의 상호 관련 운영 체제로 발전하였다. (역사 참조)
유닉스 계열 운영 체제는 유닉스에서 파생한 계열이며 시스템 V, BSD, GNU/리눅스,와 같은 주된 하부 분류가
몇 가지 있다. 유닉스라는 이름은 어느 운영 체제와도 사용할 수 있게 한다는 것을 표명한 오픈 그룹의 상표이다.
유닉스 계열은 원래의 유닉스를 닮은 커다란 집합의 운영 체제들을 가리키는 데 흔히 쓰인다.
유닉스 계열 운영 체제는 다양한 컴퓨터 아키텍처에서 돌아간다.
이들은 비즈니스 분야의 서버와 학술 및 공학 환경에서의 워크스테이션에서도 쓰인다.
GNU/리눅스와 BSD와 같은 자유 유닉스들은 이러한 분야에서 널리 쓰인다.
HP의 HP-UX와 IBM의 AIX는 제조업체의 하드웨어에만 동작하도록 설계되어 있다.
솔라리스와 같은 것들은 x86 서버와 PC를 포함한 여러 종류의 하드웨어에서 돌아간다.
넥스트스텝, 마하, FreeBSD에서 파생한 하이브리드 커널 기반의 BSD류인 애플의 맥 OS X은 유닉스 계열이
아니었던 애플의 초기 맥 OS를 대체하였다. 유닉스의 정보 처리 상호 운용성은 POSIX 표준을 확립함으로써 드러난다.
POSIX 표준은 이것이 비록 다양한 유닉스 계열을 위해서 만들어지기는 하였으나
다른 어떠한 운영 체제에라도 적용할 수 있다.
BSD 및 BSD 계열 : 이 부분의 본문은 BSD입니다.
월드 와이드 웹을 위한 최초의 서버는 BSD 기반의 넥스트스텝에서 실행하였다.
유닉스 계열의 하부 집합 가운데 하나로 BSD 계열이 있다. 여기에는 FreeBSD, NetBSD, OpenBSD를 포함한다.
이러한 운영 체제들은 웹 서버에서 가장 쉽게 찾을 수 있지만 개인용 컴퓨터 운영 체제로의 역할도 한다.
인터넷은 BSD와도 많은 관련이 있는데, 네트워크에 연결하여 데이터를 주고 받는 데 흔히 쓰이는
현재의 프로토콜들 가운데 다수가 BSD에서 정의하여 널리 쓰이게 된 것이다.
또, 월드 와이드 웹은 넥스트스텝이라는 BSD 기반 운영 체제를 실행하는 수많은 컴퓨터에서 처음 입증되었다.
BSD는 유닉스에 뿌리를 두고 있다. 1974년에 캘리포니아 대학교 버클리는 최초의 유닉스 시스템을 설치하였다.
시간이 지나 컴퓨터 과학부의 학생들과 직원들은 그곳에서 문서 편집기와 같은 새로운 프로그램을 이러한
것들에 일찍이 추가하기 시작하였다. 버클리 대학교가 최초의 유닉스 시스템이 설치된 새로운 VAX 컴퓨터를
1978년에 도입하였을 때 대학생들은 컴퓨터 하드웨어의 가능성을 이용하기 위하여 유닉스를 수정하였다.
미국 국방부의 방위고등연구계획국이 이에 관심을 가져 프로젝트에 투자하기로 결정하였다.
수많은 학교와 회사, 정부 단체들은 이를 알아채고 AT&T에서 제공하는 공식적인 것이 아닌
버클리 버전의 유닉스를 사용하기 시작하였다. 1985년에 애플을 떠났던 스티브 잡스는 넥스트스텝이라
불리는 BSD류를 실행하는 고성능 컴퓨터를 제조하였던 기업 NeXT사를 세웠다.
이러한 컴퓨터들 가운데 하나는 팀 버너스 리가 최초의 웹 서버로 월드 와이드 웹을 만드는 데 사용하였다.
OS X : 이 부분의 본문은 OS X입니다.
맥 OS X은 매킨토시 컴퓨터에 미리 최신으로 설치되어 있으면서도 애플이 개발하여 판매한 사유 그래픽 운영 체제이다.
맥 OS X은 1984년 이후로 애플의 사유 운영 체제였던 원래의 맥 OS의 뒤를 잇는 것이다. 전작과 달리 맥 OS X은
1980년대 2/4 분기부터 애플이 1987년 초에 이 회사를 사들일 때까지 NeXT에서 개발한 기술로 만든 유닉스 운영 체제이다.
이 운영 체제는 1999년에 맥 OS X 서버 1.0이라는 이름으로 처음 출시하였으며 그 뒤 2001년 3월에 데스크톱 지향 버전인
맥 OS X v10.0을 출시하였다. 그 뒤로 맥 OS X의 "클라이언트", "서버" 에디션 여섯 가지가 공개되었으며, 최신 제품은
2014년에 출시된 OS X 요세미티이다. 서버 에디션인 맥 OS X 서버는 구조적으로 데스크톱의 것과 비슷하지만
일반적으로 애플의 매킨토시 서버 하드웨어에서 돌아간다. 맥 OS X은 메일 전송 에이전트, 삼바, LDAP 서버,
DNS 등을 비롯한 네트워크 서비스에 접근할 수 있게 하는 워크 그룹 관리 및 관리 소프트웨어 도구를 포함하고 있다.
플랜 9 : 이 부분의 본문은 플랜 9 (운영 체제)입니다.
켄 톰프슨, 데니스 리치, 더글라스 맥길로이는 벨 연구소에서 유닉스 운영 체제를 개발하기 위하여 C 프로그래밍 언어를
설계하고 개발하였다. 벨 연구소의 프로그래머들은 현대의 배포 환경을 위해 계획된, 플랜 9와 인페르노를 개발하기
시작하였다. 플랜 9는 네트워킹 운영 체제로 발돋움하기 위하여 계획된 것이었으며 당시 그래픽이 제공되지 않았던
유닉스와 달리 그래픽을 내장하였다. Lucent 공중 허가 사용 허가서 하에 출시되었다.
인페르노는 Vita Nuova Holdings에 팔려 GPL/MIT 라이선스로 배포되고 있다.
리눅스와 GNU : 이 부분의 본문은 GNU, 리눅스, 리눅스 커널입니다.
리눅스의 데스크톱 배포판인 우분투.
안드로이드는 리눅스 커널을 이용하는 대중적인 모바일 운영 체제이다.
리눅스는 BSD 및 그 변종과 달리 실제 유닉스 코드 없이 개발된 유닉스 계열 운영 체제이다.
슈퍼컴퓨터에서부터 손목시계에 이르기까지 다양한 기기에 쓰인다. 리눅스 커널은 오픈 소스 라이선스로
배포되므로 누구나 코드를 읽고 수정할 수 있다. 리눅스는 다양한 전자 기기에서 동작하도록 수정되고 있다.
GNU 프로젝트는 완전한 원래의 코드를 제외하고 유닉스와 비슷하게 완전하게 자유롭고 열려 있는
운영 체제를 만들고 싶어하는 프로그래머들의 협동적인 노고 그 자체이다.
이 프로젝트는 1983년에 리처드 스톨만이 시작하였고 대부분의 리눅스의 수많은 부분을 책임지고 있다.
이 까닭에 리눅스는 GNU/리눅스로 불리기도 한다. 실질적으로 모든 운영 체제를 위한 수많은
소프트웨어가 GNU 일반 공중 사용 허가서 하에 배포된다. 이 가운데 리눅스 커널은 핀란드의 대학교
학생이었던 리누스 토르발스의 부차적인 프로젝트로 시작되었다. 1991년에 토르발스는 이 작업에 착수하여
프로젝트에 대한 정보를 컴퓨터 학생과 프로그래머를 위한 뉴스그룹에 게시하였다.
구글 크롬 OS : 이 부분의 본문은 구글 크롬 OS입니다.
크롬은 구글이 리눅스 커널을 기반으로 설계한 운영 체제이다. 크롬은 대부분의 시간을 인터넷으로
보내는 이용자들을 대상으로 한다. 기술적으로는 어떠한 응용 프로그램도 없는 웹 브라우저만을 이용하며
문서 작성이나 미디어 보기와 같은 작업을 위해 웹 브라우저에 쓰이는 인터넷 애플리케이션에 의존한다.
마이크로소프트 윈도
마이크로소프트 윈도는 개인용 컴퓨터에 가장 흔히 쓰이는 사유 운영 체제 계열이다.
개인용 컴퓨터를 위한 가장 흔한 운영 체제이며 약 90%의 시장 점유율을 차지하고 있다.
최신 버전은 개인용 컴퓨터의 경우 윈도 8.1이, 서버의 경우 윈도 서버 2012이다.
1981년에 IBM PC용의 오래된 MS-DOS 운영 체제에 추가 기능으로 나온 것이 기원이다.
1985년에 마이크로소프트는 개인용 컴퓨터의 비즈니스 분야를 지배하기 시작하여 수많은 산업 표준을
정립하기에 이르렀다. 윈도 XP를 시작으로 현대의 모든 윈도 버전은 윈도 NT 커널을 기반으로 하고 있다.
현재 나오는 윈도 버전은 IA-32와 x86-64 프로세서에서 동작하지만 그 이전에 나왔던 버전들은
다른 아키텍처를 지원하기도 하였다.
기타
틈새 시장의 오래된 운영 체제로는 IBM과 마이크로소프트의 OS/2, 애플 맥 OS X의 유닉스를 이용하지 않는
이전작 맥 OS, 또 BeOS와 XTS-300이 있다. RISC OS, MorphOS, 아미가OS 4도 열성적인 커뮤니티와 전문 분야를
위한 소수 플랫폼으로 개발이 이어지고 있다. DEC의 OpenVMS도 휴렛 패커드가 계속 개발하고 있다.
도스 등의 운영 체제도 FreeDOS와 같은 프로젝트를 통해 명맥을 이어가고 있다.
그 밖의 운영 체제는 운영 체제 교육용이나 학술용, 또는 운영 체제 개념의 연구 등을 위해 예외적으로 쓰인다.
학술과 연구 역할을 모두 수행하는 시스템의 전형적인 예로 미닉스가 있다.
반면 순수 연구 목적으로 쓰이는 것으로는 싱귤래리티가 있다.
구성 요소
운영 체제를 이루는 요소는 컴퓨터의 다른 부분들과 함께 동작하게 만들기 위하여 존재한다.
금융 데이터베이스부터 영화 편집 프로그램에 이르기까지 소프트웨어는 모두 소프트웨어에 쓰이는
하드웨어가 단순히 마우스나 키보드만 이용하든지 아니면 인터넷 연결같이 복잡한 방식을 이용하든지
상관 없이 하드웨어를 이용하기 위하여 운영 체제로 말미암아 실행해야 한다.
커널 : 이 부분의 본문은 커널 (컴퓨팅)입니다.
커널이 응용 소프트웨어를 컴퓨터 하드웨어에 연결하고 있다. 펌웨어와
장치 드라이버의 도움을 받아 운영 체제는 모든 컴퓨터 하드웨어 장치에 대한 가장 기초 수준의 제어권을 제공한다.
커널은 램을 통해 프로그램을 위한 메모리 접근을 관리하며 어느 프로그램이 어느 하드웨어 자원에 접근할지를 결정하며
CPU의 동작 상태를 늘 최적으로 설정 및 초기화하고 디스크, 테이프, 플래시 메모리와 같은 매체의 파일 시스템을
갖춘 장시간 비휘발성 기억 장치를 위한 데이터를 정리한다. 운영 체제 내에서의 커널의 영역과 그 구성에 따라
모노리딕 커널(monolithic kernel), 마이크로 커널(micro kernel)등으로 분류한다.
프로그램 실행 : 이 부분의 본문은 프로세스입니다.
운영 체제는 응용 프로그램과 하드웨어 사이의 인터페이스 역할을 한다.
운영 체제는 응용 프로그램 개발을 단순하게 하는 서비스의 집합이다.
프로그램을 실행하면 운영 체제가 프로세스를 만든다.
커널은 메모리와 다른 자원을 할당하여 프로세스를 만들며, 이로써 멀티태스킹 환경에서 프로세스에 대한
우선 순위를 확립하고, 메모리에 프로그램 코드를 적재하며 프로그램을 실행한다.
그 뒤 프로그램은 사용자 및 장치와 상호작용한 다음 원하는 명령을 수행하게 된다.
운영 체제는 프로세스들을 생성하거나 삭제하고, 중단시키거나 재개시킨다.
프로세스 간의 동기화와 통신, 교착상태 처리에 관한 메커니즘을 제공한다.
사용자 및 시스템 프로세스의 생성과 종료 관리
프로세스의 일시 중지와 속개
프로세스 동기화를 위한 수단의 제공
프로세스간 통신을 위한 수단의 제공
교착 상태 처리를 위한 수단의 제공
인터럽트 : 이 부분의 본문은 인터럽트입니다.
인터럽트는 주변 환경에 반응하고 상호작용하는 데에 효율적인 방법을 운영 체제에 제공하므로
운영 체제에 핵심적인 역할을 한다고 할 수 있다.
모드 : 이 부분의 본문은 보호 모드, 수퍼바이저 모드입니다.
보호 모드에서 사용할 수 있는 x86용 권한 링. 운영 체제는 어느 프로세스가 개별 모드에서 실행할 것인지 결정한다.
현대의 CPU는 여러 모드의 명령을 지원한다. 이러한 기능을 지원하는 CPU에는 두 가지 모드가 있다:
보호 모드, 수퍼바이저 모드. 수퍼바이저 모드는 메모리의 기록 및 삭제 방식을 제어하는 것과 그래픽 카드와 같은
장치와 통신하는 것과 같이 운영 체제의 커널이 하드웨어에 제한 없이 액세스해야 하는 낮은 수준의 태스크를 위해 사용한다.
반대로 보호 모드는 그 밖의 거의 모든 용도로 사용된다.
응용 프로그램들은 보호 모드 안에서 동작하며, 수퍼바이저 모드의 모든 것을 제어하는 커널과 통신해야만
하드웨어를 이용할 수 있다. CPU는 오래된 프로세서를 가상으로 구현하기 위한 가상 모드와 같이 보호 모드와
비슷한 다른 모드들을 지니고 있을 수도 있다. (이를테면 32비트에서 16비트 프로세서를,
아니면 64비트에서 32비트 프로세서를 가상으로 구현할 때)
컴퓨터가 처음 시동할 때 자동으로 수퍼바이저 모드에서 실행된다. 컴퓨터를 켜자마다 먼저 실행되는
몇 안 되는 프로그램들이 바이오스와 부트로더이며 운영 체제는 하드웨어에 제한 없이 접근한다.
그리고 운영 체제가 다른 프로그램에 대한 제어권을 보낼 때 CPU를 보호 모드에 놓을 수 있다.
메모리 관리 : 이 부분의 본문은 메모리 관리입니다.
멀티프로그래밍 운영 체제 커널은 현재 프로그램이 이용하는 모든 시스템 메모리를 관리해야 한다.
이로써 어느 특정한 프로그램이 다른 프로그램이 이미 사용하고 있는 메모리와 상호 작용하지 않게 한다.
프로그램이 시분할하므로 각 프로그램은 메모리에 독립적으로 접근해야 한다.
가상 메모리 : 이 부분의 본문은 가상 메모리입니다.
수많은 운영 체제는 하드 디스크와 램에 분산된 메모리를 이용하여 마치 가상 메모리로 불리는
메모리 덩어리가 연속적인 것처럼 프로그램을 속일 수 있다. 페이징이나 세그먼테이션과 같은
가상 메모리 어드레싱을 이용하면 커널은 어느 메모리를 각 프로그램이 주어진 시간에 사용할 수 있게 할지
설정할 수 있다. 그러므로 운영 체제가 여러 개의 태스크에 같은 메모리 위치를 사용할 수 있게 한다.
프로그램이 접근할 수 있는 메모리 범위에 없는 메모리에 접근하려고 하지만 그곳에 할당되면
커널은 프로그램이 마치 할당된 메모리를 초과 사용한 것과 같은 방식으로 인터럽트 처리한다.
유닉스에서 이러한 종류의 인터럽트를 페이지 실패라고 부른다.
커널이 페이지 실패를 감지하면 이러한 문제를 일으킨 프로그램의 가상 메모리 영역을 수정하는 것이 일반적이다.
이로써 요청된 메모리에 프로그램이 접근할 수 있게 한다.
현대의 운영 체제에서 자주 접근하지 않는 메모리는 일시적으로 디스크나 다른 매체에 저장하여 다른 프로그램에게
사용할 수 있는 공간을 제공해 준다. 이를 스왑 처리(swapping)라고 하며 이를 통해 여러 개의 프로그램이 특정한
메모리 영역을 차지할 수 있다.
멀티태스킹 : 이 부분의 본문은 멀티태스킹, 프로세스 관리입니다.
멀티태스킹은 여러 개의 독립적인 컴퓨터 프로그램을 하나의 컴퓨터에 실행시키는 것을 가리킨다.
마치 태스크들이 동시에 수행하는 것처럼 보여 준다.
대부분의 컴퓨터가 한 번에 최대 한 두개를 수행할 수 있고 이는 일반적으로 시분할을 통해 수행된다.
다시 말해 각 프로그램은 컴퓨터의 실행 시간의 일부를 사용한다.
운영 체제 커널은 스케줄러라는 프로그램이 포함되어 있는데 이 프로그램은 얼마나 많은 시간을
각 프로그램이 실행에 소비하게 할 것인지를 결정하며 여기서 실행 제어권이 프로그램에 넘어갈 수 있게 한다.
제어권은 프로그램이 CPU와 메모리에 접근할 수 있게 하는 커널로 말미암아 프로세스로 넘어간다.
나중에 다른 프로그램이 CPU를 사용할 수 있게 하기 위해 제어권은 같은 메커니즘을 통하여 커널로 반환된다.
커널과 응용 프로그램 간의 제어권 이동을 이른바 문맥 교환이라고 부른다.
디스크 접근 및 파일 시스템 : 이 부분의 본문은 가상 파일 시스템입니다.
파일 시스템은 디렉터리(폴더)를 이용하면서 사용자와 프로그램이 컴퓨터 파일을 정리하고 정렬할 수 있게 해 준다.
디스크에 저장된 데이터로 접근하는 것은 모든 운영 체제의 기본 기능이다.
컴퓨터는 더 빠른 접근, 더 높은 신뢰성을 위해, 또 드라이브의 남은 공간을 더 잘 이용하기 위한
특정한 방식으로 구조화된 파일을 이용하여 디스크에 데이터를 저장한다.
파일을 디스크에 저장하는 이러한 방식을 파일 시스템이라고 부르며 파일이 이름과 특성을 가질 수 있게 한다.
또, 이러한 파일들을 디렉터리 트리로 정렬되는 특정 계급의 디렉터리와 폴더에 저장하게 한다.
초기의 운영 체제는 일반적으로 한 종류의 디스크 드라이브와 한 종류의 파일 시스템을 지원하였다.
초기의 파일 시스템들은 용량, 속도, 또 파일 이름과 디렉터리 구조의 종류에 제한이 있었다.
이러한 제한은 설계된 운영 체제의 제한에 반영되므로 특정한 운영 체제가 하나 이상의 파일
시스템을 지원하는 것을 매우 어렵게 만들었다.
더 단순한 수많은 운영 체제들은 기억 장치의 시스템에 접근하기 위한 제한된 옵션들을 지원하였는데,
유닉스와 GNU/리눅스와 같은 운영 체제들은 가상 파일 시스템(VFS)이라는 기술을 지원한다.
유닉스와 같은 운영 체제는 공통 API를 통해 접근하는 파일 시스템이나 디자인에 관계 없이 다양한 기억 장치를 지원한다.
그러므로 프로그램을 개발할 때 장치 접근에 대한 정보를 공부하지 않아도 되게 한다.
VFS는 다양한 파일 시스템에, 특정한 장치 드라이버와 파일 시스템 드라이버를 사용하여 프로그램들이 무제한의 장치에
접근할 수 있는 기능을 운영 체제에 제공한다. 연결된 하드 드라이브와 같은 기억 장치들은 장치 드라이버를 통해 접근한다.
장치 드라이버는 드라이브의 특정한 언어를 이해하고 이 언어를 운영 체제가 모든 디스크 드라이브에
접근할 때 사용하는 표준 언어로 번역할 수 있다. 유닉스에서 이를 블록 장치의 언어라고 한다.
장치 드라이버 : 이 부분의 본문은 장치 드라이버입니다.
장치 드라이버는 하드웨어 장치들과 상호 작용할 수 있도록 개발된 특정한 종류의 컴퓨터 소프트웨어이다.
네트워킹 : 이 부분의 본문은 컴퓨터 네트워크입니다.
현재 대부분의 운영 체제는 다양한 통신 프로토콜, 하드웨어, 응용 프로그램을 지원한다.
다시 말해, 서로 비슷하지 않은 운영 체제를 실행하는 컴퓨터가 자원(유무선 연결을 이용한 연산, 파일,
프린터, 스캐너)을 공유하기 위해 같은 망에 참여할 수 있다. 네트워크는 컴퓨터의 운영 체제가 원격 컴퓨터의
자원에 접근하는 데 필수적이다. 마치 리소스가 로컬 컴퓨터에 바로 연결되어 있는 것처럼 보이게 만들어준다.
여기에는 컴퓨터의 그래픽, 사운드 하드웨어를 공유하거나 네트워킹 파일 시스템을 이용하는 등
단순한 통신에서 나오는 모든 것을 포함한다. 일부 네트워크 서비스는 컴퓨터의 자원을 투명하게 접근할 수 있게한다.
이를테면 SSH는 네트워크로 이어진 사용자들이 컴퓨터의 명령 줄 인터페이스에 직접 접근할 수 있게 한다.
보안 : 이 부분의 본문은 컴퓨터 보안입니다.
컴퓨터의 보안은 수많은 기술이 올바르게 동작하고 있는 지에 달려 있다.
또, 운영 체제는 보안을 위하여 특정 환경에 대한 권한을 사용자나 프로그램에 개별적으로 설정하고
인증 프로세스를 제공한다. 인터넷 보안은 특히 여러 사용자가 사용하는 시스템에 적절하다.
시스템을 사용하는 각 사용자는 개인 파일을 다른 사용자가 읽을 수 없게 할 수 있다.
사용자 인터페이스 : 이 부분의 본문은 사용자 인터페이스입니다.
명령 줄의 한 예. 각 명령어는 프롬프트 뒤에서 입력하면 되며 이에 대한 출력은 아래에 나타난다.
현재의 명령 프롬프트가 아래에 있다.
그래픽 사용자 인터페이스의 한 예. 프로그램들은 화면 위에 그림의 모습을 띠고 있으며 파일,
폴더, 응용 프로그램들은 아이콘과 기호의 모습을 띤다. 마우스는 컴퓨터를 탐색하는 데 쓰인다.
어떠한 종류의 입력을 받는 모든 컴퓨터는 사람이 컴퓨터와 소통할 수 있게 하는 사용자 인터페이스가 필요하다.
키보드, 마우스와 같은 장치들이 이러한 역할을 하지만 사용자 인터페이스는 이를 위한 소프트웨어로
이루어진다. 사용자 인터페이스는 역사적으로 컴퓨터 명령어를 한 줄씩 입력해 나가는 명령 줄 인터페이스와
일반적으로 창, 단추, 아이콘을 이루는 시각 환경이 존재하는 그래픽 사용자 인터페이스로 나뉜다.
그래픽 사용자 인터페이스 : 이 부분의 본문은 그래픽 사용자 인터페이스입니다.
현대의 대부분의 컴퓨터 운영 체제는 그래픽 사용자 인터페이스(GUI)를 지원한다.
마이크로소프트 윈도와 맥 OS와 같은 일부 컴퓨터 시스템에서 GUI는 커널에 통합되어 있다.
기술적으로 그래픽 사용자 인터페이스는 운영 체제의 서비스가 아니지만 운영 체제 커널에 통합하면
GUI가 출력 명령을 수행하는 데 필요한 수많은 문맥 교환을 없앰으로써 GUI를 더 반응적으로 만들 수 있다.
다른 운영 체제로는 그래픽 하부 시스템을 커널과 운영 체제로부터 분리시키는 모듈성이 있다.
1980년대 유닉스에서 VMS 등은 이러한 방식으로 만들어진 운영 체제였다. GNU/리눅스 및 맥 OS X 또한
이러한 방식을 취한다. 윈도 비스타와 같은 현대의 마이크로소프트 윈도는 거의 사용자 공간에 위치한
그래픽 하부 시스템을 포함하고 있지만 윈도 NT 4.0과 윈도 서버 2003 버전 사이의 그래픽 구현 루틴은
거의 커널 공간에 존재한다. 윈도 9x는 인터페이스와 커널 사이의 구별이 거의 없다.
수많은 컴퓨터 운영 체제는 사용자가 원하는 인터페이스를 만들어 설치할 수 있게 하고 있다.
X 윈도 시스템을 GNOME이나 KDE와 함께 쓰면 유닉스 및 유닉스 계열 시스템에서 이러한 설정을 할 수 있다.
수많은 윈도 셸 치환을 통해 마이크로소프트 윈도에서도 이러한 작업을 수행할 수 있는데,
윈도 셸을 교체하는 방식을 쓰지만 윈도로부터 셸 자체를 분리할 수는 없다.
실시간 운영 체제 : 이 부분의 본문은 실시간 운영 체제입니다.
실시간 운영 체제 (RTOS)는 정해진 기간 안에 수행이 끝나야 하는 응용 프로그램을 위하여 만들어진
멀티태스킹 운영 체제이다. (실시간 연산) 이러한 응용 프로그램들에는 조그마한 임베디드 시스템,
자동차 엔진 제어 장치, 산업 로봇, 우주선, 산업 제어 장치, 일부 대형 컴퓨터 시스템 등이 있다.
초기의 대형 실시간 운영 체제는 이를테면 아메리칸 항공과 IBM이 사브레 항공 예약 시스템을 위하여 개발한
트랜젝션 프로세싱 퍼실리티(TPF)가 있다. 일부 임베디드 시스템은 실시간 연산을 지원하지 않더라도
심비안 OS, 팜 OS, BSD, GNU/리눅스와 같은 운영 체제를 이용한다.
취미 활동을 통한 운영 체제 개발
운영 체제 개발은 컴퓨팅에 취미를 둔 사람들이 관여하는 가장 복잡한 활동들 가운데 하나이다.
취미로 만드는 운영 체제는 기존의 운영 체제로부터 직접적으로 코드를 가져오지 않은 것으로 분류될 수 있으므로,
사용자들과 활동 개발자들의 수는 적은 편이다.
취미 활동으로 개발된 운영 체제의 예로는 ReactOS와 Syllable 등이 있다.
범위 및 논란
운영 체제는 잘 정의된 인터페이스를 가지므로 운영 체제와 응용 프로그램 간의 구분은 명확하지만,
어느 정도의 서비스를 운영 체제 안에 포함시켜야 하는가에 대한 문제는 기술적인 문제일뿐만 아니라
사업적인 문제이기도 하다. 이 문제는 다음의 경우에 분명히 드러난다.
1998년 미국 법무부는 마이크로소프트에 대해 소송을 제기하였는데, 요점은 마이크로소프트가
운영 체제에 너무 많은 기능을 포함시켜 응용 프로그램 제작업체들에게 피해를 주었다는 것이다.
32비트와 64비트의 차이 : 이 문단의 내용은 출처가 분명하지 않습니다.
지금 바로 이 문단을 편집하여, 참고하신 문헌이나 신뢰할 수 있는 출처를 각주 등으로 표기해 주세요.
검증되지 않은 내용은 삭제될 수도 있습니다. 내용에 대한 의견이 있으시다면 토론 문서에서 나누어 주세요.
(2014년 8월 21일에 문단의 출처가 요청되었습니다.)
32비트는 64비트에 비해 호환성이 좋다고 알려져있다.
하지만 32비트 같은 경우 램을 3.25GB까지밖에 인식을 못한다. 고로 아무리 램을 더 많이 꼽아도 의미가 없다는 뜻이다.
반면에 64비트 같은 경우에는 램 인식에 제한이 없으므로더욱 좋은 프로그램을 구동 시킬 수 있게된다.
(최근에는 64비트의 호환성도 많이 개선이 되었음)