iocp 워커 스레드에서 하나의 소켓에 대한 패킷이 뭉쳐서 워커 스레드들한테 분산대서 들어갈수도 있나요?

익명 사용자의 이미지

iocp 워커 스레드에서 하나의 소켓에 대한 패킷이 여러개로 뭉쳐서 오거나 작게 와서 워커 스레드들한테 분산대서 들어갈수도 있나요?
만약 그렇게 대면 순서를 알수가 없으니 조립을 못하게 되는데 이럴때는 어떻게 해야 하나요

vagabond20의 이미지

꼭 같은 경우는 아닐지 모릅니다. (아래는 개념정도이니 다른 고수 분들의 답변이 있을겁니다.)

외부와의 통신에서 소켓을 쓸 경우든, 한 시스템 내에서 인터프로세싱을 큐나 소켓 등, 여하한 방법으로 하든지 (제가 경험한 선에서는) 패킷안에 들어있는 데이타가 완벽하게 순서대로 들어갔다고 보지 않고 프로그램을 짭니다.

또한 순서대로 들어갔다 손 처도, 보내는 쪽과 받는쪽이 원하는 크기대로 포맷에 맞게 패킷이 오고 간다고 생각 하지 않고 프로그램을 짭니다.

특히나 멀티 스레드 로 처리해야 할 경우에는 그러한 조건들 (첫째 - 순서대로 여야 한다, 둘째 - 정해진 크기대로 패킷에 들어있어야 한다) 을 감안해서 프로그램을 짜야 합니다. 그러다 보니 송수신 프로그램이 좀 복잡해 집니다. 즉, 양쪽에서 (특히 받는 쪽에서) 버퍼를 가지고 데이타 내부의 sequence number 등을 참조해 가면서 (버퍼에서) 빼 내서 후방에 있는 스레드들에게 포맷에 맞는 데이타를 공급하게 해야 합니다.

[송신 프로그램] -> [소켓] -> (네트워크) -> [소켓] -> [수신프로그램] -> [버퍼] -> [데이타 조립 및 공급 프로그램] -> [데이타 처리용 다중 스레드 1 ~ N]

글로만 쓰려면 이렇게 구름잡는 얘기가 되고, 그렇다고 특정 코드를 여기 올리는것도 별 의미가 없을것같고, 그냥 개념적인것을 써 보았습니다.

여의도자바

shint의 이미지

제가 연습하던 소스를 적어봅니다.
http://blog.daum.net/knightofelf/1165

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

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

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

댓글 달기

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