전체 글 266

Ring buffer(Circular buffer) 고찰

링버퍼 구현체를 찾아보면, 다양한 방법들로 구현이 되어 있다. 이미 하이레벨 언어에서는 기본적으로 지원해주기에, 직접 구현해서 쓸 일을 별로 없는 것 단일 배열로 구현한 형태를 기준으로_HEAD와 _TAIL을 가리키는 포인터 형태가 일반적이다.HEAD는 PUT할 위치를 가르킨다.TAIL은 GET할 위치를 가르킨다.그러면, 내부 멤버변수는 배열, HEAD, TAIL 총 3개, 여기에 SIZE 를 추가하면 총 4개다. 데이터의 크기를 담을 SIZE 변수가 있으면, 비거나, 꽉찬 상태를 체크하기가 쉽다. SIZE변수가 없는 경우는 어떨까?? HEAD와 TAIL로 사이즈를 구하는 것은 불가능 하다. 비었을 경우나, 꽉찬 경우 모두 HEAD == TAIL이 성립하기 때문이다. 이것을 해결한 구현방법은 배열 생성시..

dev 2017.04.19

IO(input/output) model

IO 모델 전통적인 IO 모델(Blocking I/O)blocking io를 사용하는 방법으로, Multi-Threaded Request-Response 형태이다. concurrent 요청을 처리하기 위해서, 쓰레드를 관리해 사용한다. IO가 시작되었을때, 어플리케이션이 blocked, IO가 끝날 때까지 대기 프로세스 단계클라이언트가 서버로 요청서버는 내부적으로 한정된 스레드 풀을 유지 관리하여 클라이언트 요청에 서비스를 제공서버는 무한루프에 있으며, 클라이언트 요청을 기다림서버가 다수의 요청을 받음서버가 하나의 요청을 선택(SELECT)쓰레드풀로 부터 하나의 쓰레드를 선택요청을 쓰레드에 할당쓰레드에서 bloking io를 처리(ACCEPT, RECV) 및 응답준비쓰레드는 응답을 서버로 보냄서버는 다시..

dev 2017.04.03