동시성, 병렬, 비동기, 논블럭킹과 컨셉들
(black7375.tistory.com)간단한 용어정리부터 시작해 그래픽, 반도체까지 폭넓게 다루어보았습니다.
- 용어
- 동시성 / 병렬
 - 비동기 / 논블로킹
 - 선점형 / 비선점형
 
 - 운영체제와 프로세서
- 운영체제
 - 프로세서
 
 - 코루틴과 파이버
- 파이버
 - 코루틴
 
 - 제네레이터, Async/Await, 컨티뉴에이션
- 제네레이터
 - Async / Await
 - 컨티뉴에이션
 
 - Promise와 Future
 - I/O 멀티플렉싱
- 멀티플렉싱
 - 소켓
 - I/O 모델들
 
 - 링버퍼, 최신 I/O 모델, LMAX Distruptor
- 링버퍼
 - 최신 I/O 모델
 - LMAX Disruptor
 
 - 동기화 프리미티브
- 필요성
 - 스레드 안전
 - 스핀락
 - 뮤텍스
 - 세마포어
 - STM
 - GIL
 
 - 다른 스크립트 언어의 접근법과  Reactor/Proactor 패턴
- Ractor (루비)
 - Node.js (Reactor 패턴)
 - Proactor 패턴
 
 - CSP와 액터
- CSP
 - 액터
 
 - 그린 쓰레드, 고루틴 그리고 최신 비동기 런타임 기술들
- 그린 쓰레드
 - 최신 CSP 런타임
 - 최신 액터 런타임
 
 - 병렬
- SIMD와 파이프라이닝
 - OpenMP & MPI
 - 최신 병렬 기법
 - 람다 아키텍처
 
 - GPU
- 파이프라인과 쉐이더
 - 모니터
 - 버퍼링
 - 수직동기화
 - 프레임 페이싱과 빔 레이싱
 - 컴포지터
 - 그래픽 API / 라이브러리
 
 - 기타 칩
- 개요
 - DSP
 - FPGA
 - TPU
 
 - 참고
 
동기와 비동기는 작업완료를 누가 확인하는가
블로킹과 논블로킹은 제어권한이 있는가
이 말을 수많은 블로그에서 똑같이 되풀이하고 있던데, 원 출처가 어딘지 궁금합니다.
대부분의 블로그는 서로가 서로를 참조하기에 바빠서 원문을 짐작할 수가 없었고, 그나마 찾은 건 IBM 의 AIO 문서 뿐인데, 이건 커널 io 에서만 한정지어서 얘기되는게 아닌가 싶어서요. 그리고 저 구분법도 그 자체로 논란이 있다고 들었습니다.
공신력있는 판단 기준인지요?
우선 동기/비동기는 회로쪽 기반으로 하면 될 것 같습니다.
동기회로는 타이밍을 위해 클럭을 이용하고, 비동기는 이벤트나 다른 입력에 의해 트리거되는 방식이죠.
즉,  비동기 API는 동일하게 콜백등에 의해 트리거되는 방식이라고 정의해도 무리는 없을 듯 합니다.
https://developer.mozilla.org/en-US/docs/…
블로킹/논블럭킹 API는 작업을 반드시 기다려야 하는가 여부가 정의로서 적절합니다.
다만, 기다리지 않기 위해서 호출한 함수가 제어권을 가지는 구현이 있어야 하기 때문에 그렇게 많이 설명하는 경향이 큰 것 같네요.
https://nodejs.org/en/docs/guides/blocking-vs-non-blocking/
간략히 넘어가고자 생략했었는데 이 내용을 추가적으로 넣어보도록 하겠습니다.
적어주신 말씀에 모두 동의합니다. 그러나 이 두 기준축을 사분면으로 한 단면에 그려야 하는가, 그릴 수 있는가, 적절하게 구분되는가에 대해선 여전히 확신을 가지기 어렵네요. 제겐 Blocking과 Sync가 개념적으로 90%의 맥락을 같이 하는 느낌입니다. Non-Blocking&Async도 마찬가지입니다.
Blocking-Sync와 Non-Blocking-Async가 함께 쓰이는 경우가 많지만 구분이 필요한 경우들이 있습니다.
- Blocking-Async: Select같은 I/O 멀티플렉싱
 - Non-Blocking-Sync: 데이터 폴링(polling)
 
때문에 저는 오히려 구분해 사용하는게 맞다고 생각합니다.
말씀주신 예시들에 대한 이해가 거의 없어서 더 공감이 잘 안되는 것 같네요.
https://incredible-larva.tistory.com/entry/… 이 글에선 아래와 같이 설명하고 있습니다:
결국 select를 요청한 user process가 return 받은 값을 보고 후속 작업 유무를 판단하는 것이다. 예측할 수 없게 인입되는 여러 I/O 요청이 한 번에 관리 되고 있기에 Asynchronous하다고 보는 경우도 있지만 결국 실제 개별 I/O 동작은 Synchronous 한 동작을 보인다는 것.
이에 대해선 어떤 의견을 가지고 계신지 궁금합니다. 사실 저는 이 시점에서, 더이상 이 2x2 구분법이 무의미하다고 느껴졌습니다. 도메인마다, 관점마다 해석이 분분한 것 같아서요.
이어서, kernel의 응답을 기다리다보면 kernel에서 결과 값이 준비되었다는 callback 신호가 오고 user process는 자신의 buffer로 데이터를 복사해오는 모습을 보여준다.
이 부분이 위에서 동의하신 콜백에 의한 트리거 방식이기 때문에 굳이 구분/정의해야 한다면 Blocking-Async라고 부르는게 맞는 것 같구요.
관점에 따라 애매하기 보이는 경우가 있을수도 있다고 생각합니다.
다만, 폴링이 확실한 예제인데요,
https://en.wikipedia.org/wiki/Polling_(computer_science)
폴링의 경우 데이터가 준비되었는지를 반복적으로 확인하기 때문에 Sync-Blocking의 적절한 예제입니다.