P237
연습 문제
✔시스템 내 전체 프로세스의 수를 조절하는 것으로, 장시 스케줄링 또는 작업 스케줄링이라 불리는 스케줄링 수준은 무엇인가?
// 고수준 스케줄링
✔ 어떤 프로세스 내에 CPU를 할당하고 어떤 프로세스를 대기 상태로 보낼지 등을 결정하는 스케줄링 수준은 무엇인가?
// 저수준 스케줄링
✔ 어떤 프로세스가 CPU를 할당받아 실행 중이더라도 운영체제가 CPU를 강제로 빼앗을 수 있는 스케줄링은 무엇인가?
// 선점형 스케줄링
✔ 현재 입출력을 진행하는 프로세스로, 사용자와 상호작용이 가능하여 상호작용 프로세스라고도 불리는 것은 무엇인가?
// 전면 프로세스
✔ 준비 큐에 도착한 순서대로 CPU를 할당하는 비선점형 스케줄링 알고리즘은 무엇인가?
// FCFS
✔준비 큐에 있는 프로세스 중 실행 시간이 가장 짧은 작업부터 CPU를 할당하는 비선점형 스케줄링 알고리즘은 무엇인가?
// SJF
✔ SJF 스케줄링 알고리즘의 단점으로 크기가 큰 작업이 계속 뒤로 밀리는 현상을 무엇이라 하는가?
// 아사 현상
✔ 아사 현상을 해결하는 방법을 설명하시오.
// 에이징 기법 - 프로세스가 양보할 수 있는 상한선을 정합니다.
✔ 서비스를 받기 위해 대기한 시간과 CPU 사용 시간을 고려하여 우선순위를 정하는 스케줄링 알고리즘은 무엇인가?
// HRN
✔ 프로세스가 할당받은 시간동안 작업하다가 작업을 완료하지 못하면 준비 큐의 맨뒤로 가서 다음 자기 차례가 올 때까지 기다리는 선점형 스케줄링 알고리즘 중 가장 단순한 것은 무엇인가?
// 라운드 로빈 스케줄링
✔ 타임 슬라이스의 크기와 문맥 교환의 관계를 설명하시오.
// 타임 슬라이스는 프로세스에게 주어지는 CPU 이용 시간입니다.
타임 슬라이스가 작으면 문맥교환이 자주 일어나며, 클 경우 문맥 교환이 적어집니다.
✔ 기본적으로 라운드 로빈 방식을 사용하지만, CPU를 할당받을 프로세스를 선택할 때 남아 있는 작업 시간이 가장 적은 것을 선택하는 스케줄링 알고리즘은 무엇인가?
// SRT
✔ 우선순위에 따라 준비 큐를 여러 개 사용하며 고정형 우선순위를 적용하는 스케줄링 알고리즘은 무엇인가?
// 다단계 큐 스케줄링
✔ 우선순위에 따라 준비 큐를 여러 개 사용하며, 프로세스가 CPU를 사용한 후 우선순위가 낮아지는 특징을 가진 스케줄링 알고리즘은 무엇인가?
// 다단계 피드백 큐 스케줄링
✔ 다단계 피드백 큐 스케줄링에서 마지막 큐에 있는 프로세스의 타임 슬라이스 크기는 얼마인가?
// 무한대에 가깝습니다.
✔ 다단계 피드백 큐 스케줄링에서 우선순위가 낮아질수록 타임 슬라이스의 크기는 어떻게 변하는가?
// 할당 받을 기회가 낮으므로 할당받았을 때 오래 사용하도록 타임 슬라이스 크기를 높여줍니다.
✔ 다단계 피드백 큐 스케줄링에서 마지막 큐눈 어떤 스케줄링 알고리즘처럼 동작하는가?
// FCFS
심화 문제
✔ 스케줄링의 단계와 그 특징을 설명하시오.
// 스케줄링 단계 = 작업 대기, 보류 프로세스, 활성 프로세스, 실행 프로세스, 작업 종료
CPU 스케줄링은 규모에 따라 고수준, 중간 수준, 저수준 스케줄링을 구분합니다.
1) 작업 대기 ~ 보류 프로세스
=> 전체 시스템의 부하를 고려하여 작업을 시작할지 말지 결정합니다.
2) 보류 프로세스 ~ 활성 프로세스
=> 시스템에 과부하가 걸려서 전체 프로세스 수를 조절해야 한다면 이미 활성화된 프로세스 중 일부를 보류 상태로 보냅니다.
3) 활성 프로세스 ~ 실행 프로세스
=> CPU 스케줄러가 필요에 따라 준비 상태에 있는 프로세스를 실행 상태로 옮기기도 하고, 대기 상태로 보내기도 하며, 타임 아웃으로 준비 상태로 보내기도 합니다.
4) 작업 종료
=> 프로세스 종료
✔ 스케줄링의 목적을 설명하시오.
// 1) 공평성 - 모든 프로세스가 자원을 공평하게 배정받아야 합니다.
2) 효율성 - 시스템 자원이 유후 시간 없이 사용되도록 스케줄링합니다.
3) 안정성 - 우선순위를 사용하여 중요 프로세스가 먼저 작동하도록 합니다.
4) 확장성 - 프로세스가 증가해도 시스템이 안정적으로 작동하도록 조치해야 합니다.
5) 반응 시간 보장 - 시스템은 적절한 시간 안에 프로세스의 요구에 반응해야 합니다.
6) 무한 연기 방지 - 특정 프로세스의 작업이 무한히 연기되어서는 안 됩니다.
✔ 선점형 스케줄링과 비선점형 스케줄링을 비교하여 설명하시오.
// 선점형 스케줄링은 실행 중인 프로세스를 중단하고 새로운 프로세스를 실행시킬 수 있습니다.
비선점형 스케줄링은 실행 중인 프로세스를 멈출 수 없으며 실행이 완료되어야 다음 프로세스를 실행할 수 있습니다.
✔ 스케줄링 알고리즘의 선택 기준에 대해 설명하시오.
// 1) CPU 사용률 : 전체 시스템의 동작 시잔 중 CPU가 사용된 시간을 측정하는 방법입니다.
2) 처리량 : 시스템이 정상적으로 작동한다면 일정 시간 후 작업이 끝납니다.
3) 대기 시간 : 작업을 요청하더라도 실제 작업이 이루어지기 전까지는 대기 시간이 필요합니다.
4) 응답 시간: 대화형 시스템에서는 사용자의 요구에 얼마 만에 반응하는지가 중요합니다.
5) 반환 시간: 반환 시간은 대기 시간과 실행 시간을 더한 값입니다.
✔ FCFS, SJF, HRN 스케줄링의 특징을 설명하시오.
// FCFS(First Come First Served)란 준비 큐에 도착한 순서대로 CPU를 할당하는 방식입니다.
SJF(Shortest Job First)란 준비 큐에 있는 프로세스 중에서 실행 시간이 짧은 순서대로 CPU를 할당하는 방식입니다.
HRN(Highest Response Ratio Next)이란 SJF의 아사 현상을 해결하고자 개발되었으며, 서비스를 받기 위해 기다린 시간과 CPU 사용 시간을 고려하여 스케줄링합니다.
✔ 라운드 로빈, SRT, 다단계 큐, 다단계 피드백 큐 스케줄링의 특징을 설명하시오.
// 라운도 로빈(Round Robin)이란 타임 슬라이스 크기만큼 프로세스가 실행하고 완료하지 못한 프로세스는 준비 큐 맨 뒤로 가서 자기 차례를 기다리는 방식입니다.
SRT(Shortest Remaining Time)란 라운드 로빈 방식을 사용하면서 CPU를 할당받을 프로세스를 선택할 때 남아 있는 작업 시간이 가장 적은 프로세스를 실행시키는 스케줄링입니다.
다단계 큐 스케줄링(Multilevel queue)이란 우선순위별로 준비 큐를 나누고 우선순위가 높은 순으로 실행시키는 스케줄링입니다. 우선순위가 높은 상위 큐 프로세스의 작업이 끝나기 전까지 하위 큐 프로세스는 실행시킬 수 없습니다.
다단계 피드백 큐 스케줄링(Multilevel feedback queue)이란 우선 순위별로 준비 큐를 나누고 우선 순위가 높은 순으로 실행시킵니다. 하지만 타임 슬라이스만큼 실행하고 완료하지 못한 프로세스는 한 단계 낮은 준비 큐에 맨 뒤로 가 대기하여 낮은 우선순위 프로세스의 실행이 연기되는 문제를 해결합니다.
✔ 아사 현상과 에이징에 대해 설명하시오.
// 아사 현상이란 작업 시간이 길다는 이유만으로 프로세스의 순서가 계속 뒤로 밀려 실행이 연기 되는 현상입니다.
에이징이란 아사 현상을 해결하고자 프로세스가 양보할 수 있는 상한선을 표시하여 순서를 양보할 때마다 나이를 한 살씩 먹어 상한선까지 양보하도록 규정하는 방식입니다.
✔ 타임 슬라이스의 크기를 정하는 것과 시스템 효율성에 대해 설명하시오.
// 타임 슬라이스의 크기는 되도록 작게 설정하되 문맥 교환에 걸리는 시간을 고려하여 적당한 크기로 하는 것이 중요합니다.
너무 작은 타임 슬라이스는 여러 프로그램이 동시에 실행되는 것처럼 보이며 또한 문맥 교환이 자주 발생하여 전반적인 성능이 저하됩니다. 너무 큰 타임 슬라이스는 FCFS 방식과 같아지게 되며 하나의 작업이 끝난 뒤 다음 작업이 시작되는 것처럼 보입니다.
[쉽게 배우는 운영체제] 5장 연습문제 및 심화문제 - 정리
'CS > OS' 카테고리의 다른 글
[쉽게 배우는 운영체제] 6장 연습문제 및 심화문제 - 정리 (1) | 2022.10.14 |
---|---|
[쉽게 배우는 운영체제] 5장 연습문제 및 심화문제 - 정리 (0) | 2022.10.14 |
[쉽게 배우는 운영체제] 3장 연습문제 및 심화문제 - 정리 (0) | 2022.10.11 |
[쉽게 배우는 운영체제] 2장 연습문제 및 심화문제 - 정리 (0) | 2022.10.10 |
[쉽게 배우는 운영체제] 1장 연습문제 및 심화문제 - 정리 (0) | 2022.10.09 |