multi-thread, nonblocking 소켓.. ㅠㅠ
글쓴이: sunbee / 작성시간: 월, 2004/03/29 - 5:56오후
구성
main () { nonblocking mode socket 생성 while(1) { cs = accept(...); pthread_create(&p_thread, NULL, work_thread, (void *)&cs); } } void *work_thread(void *data) { . . . do { read_size = read (cs, buf, 100); total_size += read_size; } while (total_size < 100); }
서버가 이런식으로 구성이 됩니다.
nonblocking mode 소켓일때
select(..)함수로 프로그래밍 하면 데이타가 들어왔는지, 새로운 클라이언트가 접속되었는지 알 수 있겠지만
위와 같이 구성될때는 accept(..)할때나 read(...)시 계속 EAGAIN 에러를 리턴하던데요..
work_thread에서 데이타를 받아들일때, 데이타가 들어왔는지 어떻게 알 수 있습니까???
그냥 EAGAIN 에러를 무시하고 받아들이면 되는건가요??? (그럴경우 메인이 block 되던데요..)
보통 multi-thread nonblocking 서버가 어떻게 구성되는지 알려주시면 정말 고맙겠습니다..
감사합니다..
Forums:
^^
/dev/epoll 같은것을 보시면 어떠실지요~
http://www.joinc.co.kr/modules/moniwiki/wiki.php/epoll
-----------
청하가 제안하는 소프트웨어 엔지니어로써 재미있게 사는 법
http://sozu.tistory.com
work_thread에 accept한 soket을 넘기시고 select를
work_thread에 accept한 soket을 넘기시고 select를 이용해서
recv()를 하시면 될것 같은데요.. :)
thread per connect 같은데 nonblocking이간 blocking이건
별 문제가 없지 않을까요?
non-blocking 소켓을 accept 하는건 연결이 없을경우에도
non-blocking 소켓을 accept 하는건 연결이 없을경우에도
리턴합니다. 이때는 -1을 리턴하죠.
select나 poll을 사용해서 연결 접속이 있을때 까지 기다리거나
다른 방식으로 accept를 해야 합니다.
screen + vim + ctags 좋아요~
댓글 달기