select와 pthrea의 차임점에 대해...

살자의 이미지

select 와 pthread의 차이점이라기 보다는
어떤때에 select가 사용하고, 또 어떤때에 pthread가 사용되는지..
그리고 글을보니깐 fork와 ipc를 사용한다구도 나와있는데 이방법은
또 언제 사용해야 하는지 궁금합니다.
다 각각의 최적의 상황이 있질않나 해서여...
맨날 질문만 해서 죄송합니다..
앞으로 저도 고수가 되면 답변 많이 하겠습니다..
그럼 고수님들 답변 부탁드리고 항상 감사합니다..
그럼 다들 복많이 받으세여...^^

sunyzero의 이미지

각각 특징이 있으니 ,쓰레드는 가볍고 메모리공간을 공유, 포크는 별개로 작동하게 하고(무거운대신 그 만큼 쓰레드보다는 안정하죠. 금융기관쪽에서는 그래서 거의 모든 프로세스는 다 포크합니다)

IPC는 프로세스끼리 통신하기 위한것이고, select는 멀티플렉싱때문이죠. 요샌 poll로 많이 넘어가는 추세지만요. 스티븐슨의 책을 읽어보시길 권장합니다.거의 이 아저씨 책은 바이블이죠.(단 ,한글판 절대 안되요... -_-)

========================================
* The truth will set you free.

cjy1126의 이미지

select, pthread 는 같이 사용될 수도 있고, 따로 될수도 있다고 봅니다.

select는 여러개의 fd에서 정신없이 들어오는 입력, 출력을 처리할때 사용되고, pthread는 동시에 여러가지의 일을 처리를 하기위해서 사용됩니다.

만약 비교를하려면 fork와 pthread를 비교해야되는거 아닌가합니다.

하나의 코드에서 동시에 여러가지 일을 하려면 fork나 pthread를 사용하는데, fork 프로세스를 만들어서 처리하는것이고, pthread는 쓰레드를 만들어서 처리하는것입니다.

살자의 이미지

답변 정말 감사합니다...
또 다른 질문 하나 더 하겠습니다.
동시에 여러 일을한다는 개념이 이해가 되질않아서여..
예를 들면 하나의 네트웍 서버가 여러개의 클라인언트에서 오는 요청을 받아 처리한 후 결과를 다시 전송하는 서버도 동시에 여러개를 하는 일을 하지 않나여? 그리고 여러개의 클라이언트 이니깐 connect 도 많이 할것 같은데여....
하지만 다른쪽으로 생각하면 들어오는 순서로 처리하는 것 이기때문에 동시에 한다는 것은 아닌가합니다...
이렇게 지금 정리가 안되고 있습니다....

cjy1126의 이미지

서버에는 반복서버와 동반서버가 있습니다.(말이 이상해도 참아주세요. 번역판으로봐서... 원어를 몰라요 -_-)

반복서버는 클라이언트에서 요청 b가오면, 서버는 처리하던 요청 a를 다 처리해야만 요청 b를 처리합니다. 또 다른 클라이언트에서 요청 c가오면 b를 처리하고 해주겠죠.
즉, 하나의 프로세스가 요청접수와 처리를 하는것이죠.

하지만, 동반서버는 요청을 접수하는 프로세스와 처리하는 프로세스가 따로 있습니다. 요청을 접수하는 놈은 요청을 받는대로 처리하는 놈들에게 보내주게되죠. 그럼 그 프로세스 수만큼 일을 동시에 하게되는것이죠.
즉, 요청 a가 처리중인 상태에서 요청 b가 들어가도 요청b는 요청 a의 처리여부와는 상관없이 처리가되죠.

저도 학원에서 배우고, 억지로 껴맞추는 프로그래밍이라서 자신은 없네요 :cry:

sjang의 이미지

동시에 작업한다???

엄밀히 말하면 컴퓨터 안에서는 그런일이 안 일어나지요.

왜냐하면 CPU는 오직 하나의 작업만 수행할 수 있으니까요...

다만, 동시에 처리하는 것처럼 여러작업을 이리저리 왔다갔다 하면서

처리하는 것이죠. 그 시간이 너무 짧아서 동시에 처리는 것처럼 보이는 것이겠지요.

여러 클라이언트에서 요청이 온다고 할 때, 각 요청에 대해서 쓰레드를

만들어서 처리할 수 있습니다. 각각의 쓰레드는 독립적으로 동작하는 것으로

생각해도 되지요. 짧은 time slot으로 이리저리 쓰레드를 옮겨 다니며

CPU가 빠쁘게 처리할 겁니다. 여러개의 쓰레드가 동시에 처리되기 때문에

"동시에 여러일을 한다." 라고 표현하는 것이지요.

The Future !!!

cjy1126의 이미지

OS가 알아서 시분할 시켜주겠죠.

linux에서 실행을 thread로 부른다고 알고있습니다.

그래서 하나의 프로세스에 하나의 필수 쓰레드가 있는것... 이걸로 압니다.

이 부분에서 추측인것은... 잘몰라서 자신이 없어서요.(그래도 올리는건 틀리면 누군가 짚어주시길 바라면서... 맞으면 확실히 아는것이되고요.)

어차피 cpu가 1개인이상 동시라는 말은 존재할 수 없지만, 요청 a와 b가 극히 짧은 시간동안에 처리되는 모듈이 아니라면... 몇번씩 context switch하면서 실행되니... 사용자 입장에서는 둘이 동시에 처리된다고 봐도 될듯합니다.

댓글 달기

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