본문 바로가기

CS/OS

Sync,Async / Blocking, Non-Blocking

Blocking vs Non-Blocking

다른 주체가 작업할 자신의 제어권이 있는지 없는지로 볼 수 있다.

 

Blocking

  • 다른 작업(함수) 호출 후 처리가 완료될 때까지 대기 후 자신의 작업 수행

Non-Blocking

  • 다른 작업(함수) 호출 후 응답을 기다리지 않고 자신의 작업 수행
  • 필요에 따라 호출한 함수의 리턴값을 처리하는 콜백함수 존재

Synchronous vs Asynchronous

결과를 돌려주었을 때 순서와 결과에 관심이 있는지 아닌지로 판단

 

Synchronous, 동기

  • 작업을 동시에 수행하거나, 동시에 끝나거나, 끝나는 동시에 시작함을 의미
  • 작업 완료를 user space에서 판단하고 다음 작업을 언제 요청할지 결정하게 됩니다.
  • 모든 I/O 요청-응답 작업이 일련의 순서를 따릅니다. 즉, 작업의 순서가 보장됩니다.

Asynchronous, 비동기

  • 시작, 종료가 일치하지 않음, 끝나는 동시에 시작을 하지 않음을 의미
  • kernel에 I/O 작업을 요청해두고 다른 작업 처리가 가능하나,작업의 순서는 보장되지 않음

 

Sync,Async / Blocking, Non-Blocking 조합

 

예시

Blocking/Sync

  • 자바의 입출력 과정, 입력을 받을 때까지 다음 코드를 수행하지 않고 기다림

Blocking/Async

  • Nginx의 하나의 스레드는 여러 소켓을 감시하면서 소켓에 데이터가 들어오는지 확인, 소켓의 입출력 상태를 감시 (Async)
  • 비동기 방식이더라도, 각 소켓에 대한 요청이 데이터가 준비될 때까지 Blocking 상태로 전환
  • 예를 들어, 소켓에서 데이터가 도착했을 때, 이를 처리하기 위해 스레드가 해당 데이터가 다 준비될 때까지 기다려야 함

 

Non-Blocking/Sync

  • 게임 중 로딩 상태를 사용자에게 실시간으로 보여주는 상황

Non-blocking/Async

  • javascript에서 api 요청 후 다른 작업하다가, 콜백을 통해 추가적인 작업을 처리하는 경우

'CS > OS' 카테고리의 다른 글

OS 부팅과정  (2) 2023.11.21
address space VS virtual memory VS swap memory  (0) 2020.07.13
데드락 (DeadLock)  (0) 2020.06.23
process synchronization(동기화)  (0) 2020.04.27
process vs thread  (0) 2020.04.27