소켓프로그램에서 non-blocking IO 시 이상한 현상이 있어 의견을 여쭙니다.

westact의 이미지

소켓서버에 하나의 프로세스에서 다수의 클라이언트를 받아 멀티쓰레드가 아닌, 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 이 반환될수가 있는지가 매우 궁금합니다.

어떤 부분 때문인지 혹시 경험하신 분이 있으시면 답좀 부탁드리겠습니다.

감사합니다.

shint의 이미지

----------------------------------------------------------------------------
젊음'은 모든것을 가능하게 만든다.

매일 1억명이 사용하는 프로그램을 함께 만들어보고 싶습니다.
정규 근로 시간을 지키는. 야근 없는 회사와 거래합니다.

각 분야별. 좋은 책'이나 사이트' 블로그' 링크 소개 받습니다. shintx@naver.com

westact의 이미지

찾아봐주셔서 감사합니다만, 제가 원하는 답이 아닌것 같습니다.

접속을 client 가 끊지 않았음에도, read 에서 0이 떨어지는 경우를 혹시 경험하신 분이 있으신지 궁금한 부분이라서요.

라스코니의 이미지

한개의 쓰레드가 600개를 처리하는 것으로 생각되는데 한개의 쓰레드가 처리할 수 있는 bottleneck에 도달하지 않았나 싶습니다.
쓰레드를 2개 또는 그 이상으로 분리하여 분담하면 어떤 결과가 나오는지 확인해 보시죠.

westact의 이미지

안타깝게도 현재 실서버라 쓰레드를 나눠 테스트를 하거나 하는걸 할 수가 없는 상황입니다. 한번이라도 죽으면 큰일나는 상황인지라 ㅠㅠ
하지만, 보통 하나의 프로세스에서 열수 있는 소켓의 수가 최대 1024개(커널 옵션을 조절하면 그 이상도 가능하지만)인 것을 감안했을때는 관계가 없지 않을까 생각합니다.
또한, 동시 접속은 많지만 채팅 서버라 실제 주고 받는 패킷은 생각보다 많지 않은 상황입니다.
서버나 클라이언트 둘 다 어느 한쪽에서 close() 함수를 호출하지 않는 한 소켓이 저절로 닫히는 상황은 없다 판단하지만, 혹나 어떤 특정한 condition 이 발생할 경우 서버쪽 커널레벨에서 close 함수 호출을 하지 않아도 소켓을 닫는 경우가 있는지 혹여 아시는 분이 있을까 의견을 듣고 싶어 글을 올리게 되었습니다.

댓글 달기

Filtered HTML

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

BBCode

  • 텍스트에 BBCode 태그를 사용할 수 있습니다. URL은 자동으로 링크 됩니다.
  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param>
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.

Textile

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • You can use Textile markup to format text.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Markdown

  • 다음 태그를 이용하여 소스 코드 구문 강조를 할 수 있습니다: <code>, <blockcode>, <apache>, <applescript>, <autoconf>, <awk>, <bash>, <c>, <cpp>, <css>, <diff>, <drupal5>, <drupal6>, <gdb>, <html>, <html5>, <java>, <javascript>, <ldif>, <lua>, <make>, <mysql>, <perl>, <perl6>, <php>, <pgsql>, <proftpd>, <python>, <reg>, <spec>, <ruby>. 지원하는 태그 형식: <foo>, [foo].
  • Quick Tips:
    • Two or more spaces at a line's end = Line break
    • Double returns = Paragraph
    • *Single asterisks* or _single underscores_ = Emphasis
    • **Double** or __double__ = Strong
    • This is [a link](http://the.link.example.com "The optional title text")
    For complete details on the Markdown syntax, see the Markdown documentation and Markdown Extra documentation for tables, footnotes, and more.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 사용할 수 있는 HTML 태그: <p><div><span><br><a><em><strong><del><ins><b><i><u><s><pre><code><cite><blockquote><ul><ol><li><dl><dt><dd><table><tr><td><th><thead><tbody><h1><h2><h3><h4><h5><h6><img><embed><object><param><hr>

Plain text

  • HTML 태그를 사용할 수 없습니다.
  • web 주소와/이메일 주소를 클릭할 수 있는 링크로 자동으로 바꿉니다.
  • 줄과 단락은 자동으로 분리됩니다.
댓글 첨부 파일
이 댓글에 이미지나 파일을 업로드 합니다.
파일 크기는 8 MB보다 작아야 합니다.
허용할 파일 형식: txt pdf doc xls gif jpg jpeg mp3 png rar zip.
CAPTCHA
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.