비대칭 다중처리 → 마스터 서버
하나의 프로세서가 모든 스케줄링 결정과 I/O 처리 그리고 다른 시스템의 활동을 취급하는 것
하나의 코어만 시스템 자료구조에 접근하여 자료 공유의 필요성이 없어지기에 간단하다. 하지만 모든 스케줄링 결정을 맡고 있는 마스터 서버가 일을 못 하면 전체 시스템 성능을 저하할 수 있는 병목이 될 수 있다.
대칭 다중 처리 (Symmetric MulitiProcessing, SMP)
거의 모든 최신 운영체제는 SMP를 사용한다. 대칭 다중 처리는 각 프로세서는 스스로 스케줄링을 할 수 있다. 각 프로세서의 스케줄러가 준비 큐를 검사하고 실행할 스레드를 선택하여 스케줄링이 진행된다.
스케줄 대상이 되는 스레드가 담기는 준비큐 전략
CPU는 프로세서 중 가장 중요한 역할을 하는 하드웨어이다. 이 CPU 안에는 물리적인 계산을 실제로 진행하는 유닛을 코어(Core)라고 한다.
CPU 안에는 한개 이상의 코어가 들어갈 수 있고 최근 하드웨어들은 점점 많은 코어를 탑재하는 추세이다.
한 프로세서에 여러 코어가 장착되어진 것을 다중 코어 프로세서라고 한다. 각 코어는 구조적인 상태를 유지하고 있어서 운영체제 입장에서는 개별적인 논리적 CPU처럼 보이게 된다.
출처 : https://velog.io/@kanamycine/멘토링-1.-멀티코어-프로세서
코어안에는 하드웨어 스래드가 장착되어 있는데 이 또한 각 코어에 여러개의 하드웨어 스래드가 장착될 수 있고, 이는 멀티 스레드 처리 코어라고 말한다.
출처 : https://juneyr.dev/thread
이 하드웨어 스레드는 명령어 포인터 및 레지스터 집합과 같은 구조적 상태를 유지한다.
그래서 운영체제 입장에서는 소프트웨어 스래드를 실행할 수 있는 논리적 CPU로 보인다. 이를 칩 다중 스레딩(Chip Multi-Threading, CMT)이라고 한다.
아래 그림은 각 코어에 2개의 하드웨어 스레드가 있다. 운영체제 입장에서는 8개의 CPU가 있는 것으로 인지한다.
하나의 코어는 오직 하나의 스레드만 실행할 수 있다. 그래서 코어속 여러개의 하드웨어 스래드는 사실 동시에 실행되는 병렬성을 가지는 것이 아닌 시간에 따라 교대로 실행되어 동시에 실행되는 것처럼 보이는 동시성을 띄고 있다.
메모리를 기다리는 동안 하나의 하드웨어 스레드가 중단되면 코어가 다른 스레드로 전환할 수 있다.
일반적으로 프로세서가 다중 스레드화 하는 데에는 2가지 방법이 있다.
거친 다중 스레딩 (coarse-grained)
매 사이클이 아닌 메모리 스톨과 같은 긴 지연시간을 가진 이벤트가 발생하면 그때 스래드를 변경한다.
세밀한 스레딩 (fine-grained)
매 사이클마다 스레드를 변경한다.
결과적으로 다중 스레드 다중 코어 프로세스는 아래 그림과 같이 두 개의 다른 스케줄링 단계가 필요하다
SMP 시스템 중 각 프로세서가 실행할 스레드를 결정하기위해 각자 준비 큐를 가지고 있는 시스템의 경우에는 부화 균등화 기능이 필요하다.
부화 균등화는 SMP 시스템이 모든 프로세서 사이에 부하가 고르게 배분되도록 도와주는 것이다. 이를 위한 방법으로는 2가지가 있다.
push migraion
특정 태스크가 주기적으로 각 프로세서의 부하 여부를 검사하고 과부하인 처리기에서 덜 바쁜 처리기로 스레드를 이동(push) 시키는 방식
pull migration
쉬고 있는 프로세서가 바쁜 프로세서를 기다리고 있는 프로세스를 가지고(pull)오는 방식
캐쉬 등의 리소스 관련 문제로 인해 스레드는 한 프로세서에서 다른 프로세서로 이주시키지 않고 대신 같은 프로세서에서 계속 실행시키면서 이용하려한다. 이를 프로세서 선호도라고 한다.
프로세서 선호도 형태
많은 시스템에서 둘 다 모두 지원하고 있다.
위에서 말했던 Load Balancing 부하 균등화는 Processor Affinity 처리기 선호도를 상쇄한다.
동일한 프로세서에서 스레드를 계속 실행시키면 캐시 메모리에 있는 데이터를 활용할 수 있다. 하지만 부하 균동화를 통해 스레드를 이동시키면 이 이점이 사라진다.
그래서 자신의 문맥에 맞춰서 잘 활용하자
모바일 시스템에서는 다중 코어 아키텍처가 채택되어 있지만, 일부 시스템은 전력 소비를 조장하는 기능을 포함하여 클록 속도 및 전력 관리 측면에서 차이가 나는 코어를 사용하여 설계된다.
big 코어는 고성능이지만 많은 에너지를 사용하여 대화형 응용 프로그램을 할당하고,
little 코어는 더 적은 에너지를 사용하지만 저성능이여서 백그라운드 배치 프로그램을 할당한다.
실시간 시스템에서는 작업 수행이 요청되었을 때 이를 제한된 시간 안에 처리해서 결과를 내주어야한다.
이 제한된 시간안에 처리하는 방식에 따라 2가지 실시간 시스템으로 분류할 수 있다.
연성 실시간 시스템 (Soft Real-Time System)
실시간 프로세스가 실시간이 아닌 프로세스들에 우선권을 가진다는 것을 보장
하지만 이것이 스케줄 되는 시점에 대해서는 아무런 보장이 없다.
경성 실시간 시스템 (Hard Real-Time System)
태스크를 반드시 마감시간까지 서비스를 받을 수 있게끔 보장한다.
마감시간까지 서비스를 받지 못 하면 해당 태스크가 실행되지 않은 것과 같은 결과를 도출한다.
[Operating System - Chapter 5] CPU 스케줄링
[운영체제 - 공룡책] Chapter 05. CPU Scheduling
[Chapter 5. CPU 스케줄링] 실시간 시스템과 실시간 스케줄링 (RM, EDF)