운영체제 9

[OS] 다중 프로그램을 메모리에 할당하는 방법 (고정 분할, 가변 분할)

모든 프로세스는 서로 다른 메모리 사이즈( 4GB, 8GB, 16GB ...)를 가지는 PC에서 모두 동일하게 실행되어야 한다. 프로세스마다 크기가 다르기 때문에 메모리의 구역을 나누는 방식은 중요한 문제가 되는데, MMU(Memory Manage Unit)라고 불리는 메모리 관리자는 fetch(메모리로 가져옴), placement(배치), replacement(재배치)를 수행하여 메모리에서 운영체제와 다양한 프로세스의 구역을 나누어 작업공간을 확보한다. 다중 프로그래밍 환경에서 fetch 수행 시에 프로세스은 고정(page)/가변(segmentation) 사이즈로 분할되어진 메모리에 할당되어지고, 메모리에 더이상 새로운 프로세스를 할당할 공간이 부족할 경우에는 이전 프로세스를 스왑영역(Swap Area..

CS/OS 2021.11.14

[OS] 프로그램이 메모리 사이즈보다 크다면? - 메모리 오버레이 기법

다음과 같은 상황을 생각해보자. - 메모리의 용량이 작을 때 이보다 큰 사이즈의 프로그램을 실행시키려면 어떻게 해야할까? - 고정 분할방식으로 나뉜 메모리의 page 사이즈보다 프로그램의 사이즈가 크면 어떻게 해야할까? 메모리공간 < 프로그램사이즈인 위와 같은 상황에서는 프로그램을 쪼개어야 메모리에 할당할 수 있다. 이 때 프로그램의 명령어와 데이터들(instructions and data)을 Module로 나누어 먼저 실행되어야하는 모듈을 메모리에 우선적으로 할당하고, 다음 모듈을 실행하기 위해서는 이전의 모듈을 swap area로 옮겨 메모리를 관리하는 방식을 메모리 오버레이 기법이라고 한다. 1번의 예에서 메모리 오버레이 기법을 통해 메모리를 관리하는 방법을 자세히 살펴보면 다음과 같다. - 현재에..

CS/OS 2021.11.14

[OS] 교착상태 (Dead Lock)

교착상태(Dead Lock)란, : 여러 프로세스가 서로의 작업이 끝나기만을 기다리며 작업을 진행하지 못하게 되는 상태 ex) 식사하는 철학자 문제 : 왼쪽->오른쪽 순으로 포크를 집어야 식사를 시작할 수 있다는 조건이 있을 때, 5명의 철학자는 각자 왼쪽의 포크를 집은 뒤 오른쪽 포크를 무한정 기다리게 되어 굶어 죽을것이다. =>교착상태 교착상태 필요조건 : 4가지를 모두 충족할 때 교착상태가 발생한다. o 상호배제 : A가 사용중인 자원을 B가 동시에 사용할 수 없다. o 비선점 : A가 사용중인 자원을 B가 뺏을 수 없다. o 점유와 대기 : 자원1을 사용(점유)하면서 자원2를 필요(대기)로 하는 상황이다. o 원형대기 : 점유와 대기상태의 프로세스들의 요청이 원형을 이룬다. 교착상태 해결방법 o ..

CS/OS 2021.08.30

[OS] 임계구역 접근방법 - 뮤텍스(Mutex)와 세마포어(Semaphore)

임계구역 (Critical Section) : 여러 프로세스가 특정 공유자원을 병행하며 읽고 쓰면 "경쟁조건이 발생했다" 라고 말한다. 이 때, 프로그램의 결과는 자원에 접근한 프로세스의 순서에 따라서 달라지는데, 이러한 영역을 임계구역이라고 한다. ex) 생산자-소비자 문제 - Producer는 물건을 생산하는 input method 를 호출한 뒤 sum을 하나 증가시킨다. - Consumer는 물건을 소비하는 output method를 호출한 뒤 sum을 하나 감소시킨다. 이 때, 둘 다 sum = 3인 상태에서 동시에 전역 변수 sum에 접근하여 (1) Producer는 sum = 4, (2) Consumer는 sum = 2로 업데이트 하려고 하면 (1)->(2) or (2)->(1) 어떤 순서로 ..

CS/OS 2021.08.30

[OS] CPU 스케줄링 방법

운영체제의 역할 중에는 CPU 작업 프로세스와 할당 순서를 관리하는 "CPU 스케줄러"의 역할이 있다. 스케쥴러는 공평하게 프로세스를 실행시키고 반응시간을 최소화, 자원의 효율성을 증가시키는 등의 목적을 가지며 이를 위한 스케줄링 방법에는 여러가지가 있다. 스케줄러 종류 o 선점형 스케줄러 (Preemptive) : 운영체제가 CPU에서 실행 중인 프로세스의 차례를 뺏을 수 있다. ==> interrupt (장점) 문맥교환(Context Switch)에 의한 낭비가 발생 (단점) CPU의 독점이 없기 때문에 전체적으로 빠른 응답시간 o 비선점형 스케줄러 (Non-Preemptive) : 한 번 실행된 프로세스가 종료될 때까지 CPU를 독점한다. ==> 일괄작업시스템 (장점) 스케줄러의 작업율이 높고, 문..

CS/OS 2021.08.10

[OS] 멀티태스킹, 멀티프로세싱, 멀티스레드

멀티태스킹, 멀티프로세싱, 멀티스레드 각각의 특징과 차이에 대해 알아보자. 이를 이해하기 위해서는 먼저 프로세스, 스레드 그리고 병렬처리에 대한 개념을 알고 있어야한다. 프로세스(Process)란, 저장장치의 프로그램을 실행하어 메모리에 load 되어진 상태이다. 프로세스 = 프로그램 + 프로세스제어블록(PCB) 스레드(Thread)란, 프로세스의 코드에 정의된 절차에 따라 CPU에 작업 요청을 하는 실행 단위이다. 즉, 작은 단위의 일(Operation)이 모여 하나의 작업(Task)이 될 때, 이 작은 단위의 일을 수행하는 것을 스레드라고 할 수 있다. JOB > TASK > OPERATION == 작업 > 프로세스 > 스레드 병렬처리(Parallel Processing) 동시에 여러 명령을 수행하여..

CS/OS 2021.08.07

[OS] 인터럽트(Interrupt)란?

초기 컴퓨터 시스템은 CPU 작업 중 입출력장치에 데이터를 통신할 일이 생기면 이를 직접 수행하는 폴링(Polling) 방식이었다. 이 때, CPU에서 입출력에 관여하는데 시간이 소요된다는 시간문제가 있었는데 이를 해결하기 위해 등장한 것이 바로 인터럽트(Interrupt)방식이다. 기존의 폴링 방식때에는 CPU만이 메모리나 주변장치에 대한 권한을 가지고 있었는데, 인터럽트 방식에서는 이 권한을 입출력 관리자에게 부여하고, CPU는 본래 역할(명령어 해석, 실행)에 충실하여 작업의 효율을 높혔다. 이 때, 입출력 관리자에게 부여한 권한을 직접 메모리 접근(DMA)라고 한다. 인터럽트 동작과정 (1) CPU에서 프로세스 실행중 I/O요청 발생시 해당 프로세스를 대기 상태로 변경. 다음 프로세스 수행 (2)..

CS/OS 2021.08.07

[OS] 운영체제의 프로세스 관리

운영체제의 여러 기능중에는 프로세스 관리가 있다. 이번 게시글에서는 프로세스란 무엇이며, 운영체제에서 어떻게 관리되는지 공부해보자. Process란 무엇인가? A process is a program in execution. : 프로세스란 실행중인 프로그램을 말한다. 컴퓨터의 저장소(HDD) 에는 많은 파일과 프로그램들이 있는데, 이를 실행시키기 위해 메모리에 load하면 프로세스로 불리는 것이다. 그리고 이 때, 프로세스는 다음 그림과 같이 메모리에 여러 영역으로 나뉘어 저장된다. o Text section : 소스코드의 명령어 o Data section : 소스코드의 전역변수 o Heap section : 동적 메모리 할당 (dynamic memory allocation) - ex. malloc, n..

CS/OS 2021.07.23

[OS] 운영체제가 도대체 뭘까?

우리가 흔히 알고있는 Windows, Linux, MaxOS, Android, IOS, Ubuntu 등등.. 운영체제(OS)는 많은 종류들이 있다. 그렇다면 OS란 무엇이고 어떤 기능들을 수행하는지 한 번 알아보자. 운영체제(OS: Operating System)란, A software that operates a computer system The one program running at all times on the computer 한마디로 표현하자면 컴퓨터 시스템을 운영하기위한 소프트웨어 이다. OS는 컴퓨터를 켜면 제일 먼저 실행되어 항상 동작하는 프로그램으로, 컴퓨터가 정보를 처리할 수 있도록 한다. 예를 들어, OS는 프로그램의 명령어들을 실행하며 동작하도록 하고, I/O 기기들을 제어하기도 ..

CS/OS 2021.07.17