소스 코드를 기록하는 남자

'Computer Science'에 해당되는 글 2건

  1. [OS] Scheduler 알고리즘
  2. Nagle Algorithm 이란 무엇인가?

[OS] Scheduler 알고리즘

Computer Science/OS

긴 포스팅은 머릿속에 들어오지 않습니다. 짧고 굵게 갑니다.

 

스케줄링 알고리즘은 크게 2 분류가 있습니다.

 

비선점, 선점

 

비선점

비선점 (Non-preemptive)

      :   프로세스가 CPU에 할당되면 그 프로세스가 종료되거나 대기 중 상태로 전환될 때까지 CPU를 점유

 

대표적인 알고리즘 : FCFS, SJF

장점 단점
1. 모든 프로세스에 대해 공정한 처리가 가능하다.
2. 프로세스 간의 오버헤드가 적다
3. 응답시간의 예측이 편하며, 일괄 처리 방식에 적합하다.
1. 긴 작업이 짧은 작업을 오래동안 기다리게 만드는 경우가 생긴다.
2. 중요 작업을 먼저 처리할 수 없다.

 

선점

선점 (Preemptive)

     : 어떤 조건이 만족되면 현재 실행 중인 프로세스의 의사와 상관없이 그것의 실행을 중단하고 다른 프로세스를 CPU에 할당

 

대표적인 알고리즘 : SRTF, RR, Priority Scheduling, Multi-level Scheduling

장점 단점
1. 높은 우선 순위를 가지는 프로세스들을 빠르게 처리할 수 있다.
2. 빠른 응답 시간을 요구하는 시스템에 용이하다.
1. 프로세스 간의 Context Switch가 자주 발생한다.
2. 우선순위가 낮은 프로세스는 starvation 현상을 겪게 된다.

Nagle Algorithm 이란 무엇인가?

Computer Science/Network

시작하기에 앞서서 제가 공부하면서 이해한 내용을 정리하는 부분이라 정확하지 않을 수도 있다는 점 인지해주셨으면 감사하겠습니다.

 

 

Nagle's algorithm is a means of improving the efficiency of TCP/IP networks by reducing the number of packets that need to be sent over the network. It was defined by John Nagle while working for Ford Aerospace. It was published in 1984 as a Request for Comments (RFC) with title Congestion Control in IP/TCP Internetworks

위키피디아의 정의를 보면 다음과 같이 정의되어 있다.

네이글's 알고리즘은 네트워크로 전송해야할 패킷을 수를 줄임으로 TCP/IP 네트워크의 효율성을 증가시킨다.

Ford Aerospace에서 근무하던 John Nagle이 정의하였으며, 1984년 RFC (IP/TCP internetwork에서 혼잡 제어)로 발표되었다.

 

 

 

Nagle 알고리즘으로 사용할 이점은 ?

  1. 패킷을 전송할 때는 전송하고자 하는 패킷의 크기와 상관없이 항상 고정적인 비용이 필요하다 (TCP에서는 40byte header). 따라서 한 번의 전송에 많은 데이터를 보내는 것은 전송 비용을 줄 일 수 있다.
  2. 여러 번에 보내던 패킷을 한 번에 보내면 얻는 이점이 있다. 적은 양을 여러 차례 보내면서 생기는 대역폭의 낭비를 줄일 수 있다는 것
  3. 대역폭 낭비를 줄임으로써 잠재적으로 발생할 수 있는 congestion collapse를 방지할 수 있다는 점.
MSS ( Maximum segment size )

if 전송할 데이터가 있으면 then
	if 윈도우 사이즈 >= MSS and 가능한 데이터 크기 >= MSS then
    	완전한 MSS segment 전송
    else
    	if 파이프에 미확인된 data가 여전히 존재 then
        	ack 가 수신될때까지 buffer에 data enqueue
        else
        	즉시 data 전송
        end if
    end if
end if

 

이 알고리즘을 사용함에 있어 문제점이 존재

  1. 다량의 write에 부정적인 영향을 준다.
  2. 실시간 시스템과의 상호 작용이 좋지 않음

larger write에서 부정적인 영향을 주는 이유는, 어떤 request-response 어플리케이션 프로토콜에서 request data는 하나의 패킷보다 클 수 있는데, 이는 임의적으로 few hundred milliseconds의 지연을 발생시킬 수 있음