[질문] blocked I/O로 TCP socket 사용시 정상상태에서 중간에

skjk의 이미지

UNIX에서 MSG_WAITALL옵션을 주지 않는 한 TCP 소켓에 대해 blocked I/O로 Maximum Segment Size보다 큰 바이트수만큼 수신을 요청한 경우엔

정상상태임에도 불구하고 지정한 바이트 수보다 적은 바이트가 전송된 후 read나 recv가 반환될 수 있고.. 이 경우 나머지 만큼 다시 수신을 시도해야 하는 것으로 알고 있습니다. (Stevens책의 readn형식으로)

근데 Stevens책에 보면 write나 send의 경우엔 에러가 나거나 signal이 발생했거나 접속이 끊긴 경우가 아니라면 무조건 지정한 바이트를 다 보낼때까지 block하고 있다고 나오더군요.. MSG_WAITALL옵션도 송신시에는 쓰이지 않구요..

수신을 할 때는 네트웍 상태에 따라 정상상태임에도 중간에 read나 recv가 반환될 수 있는데 왜 송신할 때는 write나 send가 정상상태일 때는 중간에 반환되지 않는 것일까요?

예전에 막연히 내부적으로 pipe처럼 처리되기 때문이라고 생각하고 있긴 하는데.. (글고보니 pipe도 왜 그런지 모르겠네요) 소켓 버퍼링쪽도 관련된 문제일 것 같군요..

자세하게 설명해주시면 감사하겠습니다 ^^;

kslee80의 이미지

대강, 제가 아는 선에서 답을 달겠습니다;;;
확실한게 아니니...참고;; 만 하세요..

마지막 부분에 쓰신 것처럼...
버퍼링에 의한 현상으로 보입니다;;

TCP 소켓 상에서는
send() 했을때는 소켓 버퍼에
send() 할 데이타를 넣을 뿐이며
recv() 역시 버퍼에서 값을 읽을 따름입니다.
실제로 recv buffer/send buffer 를 관리하는 것은
커널이며, 적절한 때에(...) send buffer 의 내용을 전송하며..
데이타를 받았을때는 recv buffer 에 넣는 역할을 합니다.

특히나, 적절한 때에 적절한 데이타를 전송하기 때문에
보내는측에서 send(fd, buf, 1000, 0);
받는측에서는 recv(fd, buf, 1000, 0);
이라고 해도 recv() 에서 1000 바이트를 받지 못할수도 있습니다;;;
보내는측 OS 가 1000 바이트를 전송하지 않은 죄이지요;;;
(OS 의 죄라고 하기도 모호합니다;; TCP 표준안에
구현에 대한 내용이 별로 없어서;; OS 별로 구현이 다 틀리다고 합니다;;)
그래서 recvn() 같은 평션을 만들어서 쓰게 되는 것이죠..

하지만, send() 시에는 말이 틀려지죠 =_=
send() 콜에서는 Argument 로 받은 값만큼을
send buffer 에 넣기만 하면 되기 때문에;;
중간에 리턴될 일이 없는 것이겠죠 =.=;;;

댓글 달기

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
이것은 자동으로 스팸을 올리는 것을 막기 위해서 제공됩니다.