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 |