소켓프로그램에서 non-blocking IO 시 이상한 현상이 있어 의견을 여쭙니다.
글쓴이: westact / 작성시간: 금, 2016/01/22 - 11:38오전
소켓서버에 하나의 프로세스에서 다수의 클라이언트를 받아 멀티쓰레드가 아닌, poll 의 다중입출력 방식을 통해 서버를 구현하였습니다.
간헐적으로 한가지 문제가 발생하여 해결하지 못하고 다른분들의 같은 경험이 있으신지 궁금하여 글을 올립니다.
서버입장에서 하나의 사용자가 socket 으로 접속하면, 이를 accept 한 후 setsocket 옵션을 통해
l_onoff = 1;
l_linger = 0;
로 변경과 함께 O_NONBLOCK 옵션을 추가하여 non-blocking I/O 로 통신을 하도록 하였습니다.
문제는 이와 같은 상태로 약 600명의 동시접속자가 사용하고 있을 때, 간헐적으로 클라이언트가 접속을 끊지도 아니하였는데도 불구하고 서버에서는 read() 함수로부터 0 을 반환받고, errno = ECONNRESET 으로 설정되어 클라이언트가 접속을 끊었다는 값을 받는 경우가 있는것이 문제입니다.
tcpdump 를 통해 패킷을 캡쳐했을때도, client 는 메시지를 계속 보내고 있는 상태였고, tcp flag 에 reset 이나 close 가 전혀들어오지 않았는데도 불구하고, read() 함수로부터 0 이 반환될수가 있는지가 매우 궁금합니다.
어떤 부분 때문인지 혹시 경험하신 분이 있으시면 답좀 부탁드리겠습니다.
감사합니다.
Forums:
찾아보니. 경험하신분 블로그가 있네요.
ECONNRESET read()
https://search.naver.com/search.naver?ie=utf8&sm=stp_hty&where=se&query=ECONNRESET+read%28%29
https://www.google.co.kr/?gfe_rd=cr&ei=6KehVvSFLsLU8AfCq7KwBg&gws_rd=ssl#q=read+ECONNRESET+
----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.
매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.
각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com
죄송합니다.
찾아봐주셔서 감사합니다만, 제가 원하는 답이 아닌것 같습니다.
접속을 client 가 끊지 않았음에도, read 에서 0이 떨어지는 경우를 혹시 경험하신 분이 있으신지 궁금한 부분이라서요.
한개의 쓰레드가 600개를 처리하는 것으로 생각되는데
한개의 쓰레드가 600개를 처리하는 것으로 생각되는데 한개의 쓰레드가 처리할 수 있는 bottleneck에 도달하지 않았나 싶습니다.
쓰레드를 2개 또는 그 이상으로 분리하여 분담하면 어떤 결과가 나오는지 확인해 보시죠.
그럴수도 있지 않을까 생각했습니다..
안타깝게도 현재 실서버라 쓰레드를 나눠 테스트를 하거나 하는걸 할 수가 없는 상황입니다. 한번이라도 죽으면 큰일나는 상황인지라 ㅠㅠ
하지만, 보통 하나의 프로세스에서 열수 있는 소켓의 수가 최대 1024개(커널 옵션을 조절하면 그 이상도 가능하지만)인 것을 감안했을때는 관계가 없지 않을까 생각합니다.
또한, 동시 접속은 많지만 채팅 서버라 실제 주고 받는 패킷은 생각보다 많지 않은 상황입니다.
서버나 클라이언트 둘 다 어느 한쪽에서 close() 함수를 호출하지 않는 한 소켓이 저절로 닫히는 상황은 없다 판단하지만, 혹나 어떤 특정한 condition 이 발생할 경우 서버쪽 커널레벨에서 close 함수 호출을 하지 않아도 소켓을 닫는 경우가 있는지 혹여 아시는 분이 있을까 의견을 듣고 싶어 글을 올리게 되었습니다.
댓글 달기