Java의 nio를 이용한 서버 프로그램??

loader의 이미지

자바의 nio를 접해보았습니다.

그런데, 코딩상의 미스인지 성능이 생각보다 잘 안나오네요...

혹시, 소스를 볼 수 있는 nio를 이용한 서버 프로그램이

있을까요?..

(간단한 예제 말고 실제로 많이쓰거나 좋은 성능을 보이고 있는

서버 애플리케이션으로 추천 부탁합니다. tomcat이나 cvs같은

곳에서는 안 쓸려나...)

litdream의 이미지

무례하지 않았길 바라면서...
C 의 select() 를 안보셨다면, 한번 검토해 보시는것도 좋은 생각일듯 합니다.

man select

삽질의 대마왕...

익명 사용자의 이미지

견해차가 있을 수 있으나, 자바를 사용하면서 성능을 논한다면 아이러니 하다고 보오.
자바 technology에 그 다지 관심은 없으나, Doug Lea는 개인적으로 인정할 수 밖에 없는 고수라고 생각하오.
그래서 그 사람의 홈페이지를 소개하고자 하오.
http://gee.cs.oswego.edu/dl는 홈페이지고,

Doug Lea의 여러 훌륭한 문서중 질문하신 분의 견彎?다소 차이가 있으나, 관련항목은 http://gee.cs.oswego.edu/dl/cpjslides/nio.pdf 라고 생각하오.
scalability를 중시하는 관점이지만, 멋진 문서니 꼭 보도록 하시길 바라는 바이외다.
그럼 건승을 빌겠소.

idlock의 이미지

Anonymous wrote:
견해차가 있을 수 있으나, 자바를 사용하면서 성능을 논한다면 아이러니 하다고 보오.
자바 technology에 그 다지 관심은 없으나, Doug Lea는 개인적으로 인정할 수 밖에 없는 고수라고 생각하오.
그래서 그 사람의 홈페이지를 소개하고자 하오.
http://gee.cs.oswego.edu/dl는 홈페이지고,

Doug Lea의 여러 훌륭한 문서중 질문하신 분의 견彎?다소 차이가 있으나, 관련항목은 http://gee.cs.oswego.edu/dl/cpjslides/nio.pdf 라고 생각하오.
scalability를 중시하는 관점이지만, 멋진 문서니 꼭 보도록 하시길 바라는 바이외다.
그럼 건승을 빌겠소.

음.. 어떤 성능인지 궁금합니다. , 가용성? 이식성?, 속도?, 메모리 대비..?

thkim86의 이미지

litdream wrote:
무례하지 않았길 바라면서...
C 의 select() 를 안보셨다면, 한번 검토해 보시는것도 좋은 생각일듯 합니다.

man select

C나 C++을 이용한다면 select() 대신에 FreeBSD 계열은 kqueue, Linux쪽은 epoll의 사용을 적극 검토해보세요.
서버급 Unix쪽은 aio를 이용해야 대량 접속시 문제점을 처리할 수 있습니다.

자바의 nio에 대해 언급한 문서를 읽어보긴 했지만 실제로 구현해본 적이 없어서 성능이 얼마나 나올지는 모르겠네요.

(저도 무례하지 않았기를.. 바랍니다)

kihongss의 이미지

마소 12월호에 관련 기사가 있군요.
...

[오픈 디벨로퍼] 오픈소스 NIO 서버의 대표주자, NB 서버

loader의 이미지

질문에 애매한 부분이 있었군요. 제가 말하는 성능은

NIO가 아닌 기존의 socket/thread를 썼을때 보다 IO처리가

빠르지 않았다는 것을 이야기하는 것이었습니다.
(물론 자바의 socket/thread입니다.)

답변들 감사드립니다...

atie의 이미지

원하시는 답을 못 얻으신 것 같은데... 위에 링크된 곳을 보면 어떤 패턴과 어떻게 버퍼 맵을 잡아야 성능 향상이 할 수 있는지 비교적 자세히 나와 있으니 참조를 하십시요. 정확히 어떤 것을 어떻게 테스트 했는지에 대한 언급이 없으니 더이상의 답변은 얻기가 곤란할 겁니다.

그리고, 밑에 글로 미루어 짐작하면, 대략 600 건 이상의 동시 접속을 테스트해봐야 성능 비교가 가능하니 참고 하시고요.
http://www-106.ibm.com/developerworks/library/j-nioserver/?ca=dnt-55

----
I paint objects as I think them, not as I see them.
atie's minipage

익명 사용자의 이미지

음...제가 알기로 IO 속도를 위해서 NIO 를 선택하셨다면 큰 기대는 하지 않는 쪽이 좋을 듯 합니다. 저도 이리 저리 자료를 찾아보고 테스트를 해봤지만 NIO 가 IO 속도에서 기존 방식의 자바 IO 보다 크게 빠르지는 않은 듯 합니다.

처음 NIO 가 나왔을 때 Sun에서 선전하던 말이 있엇지요. "Scalable IO, Non-blocking IO" 였습니다. NIO 의 의미는 가용성이지 속도는 아닌 듯 합니다. reactor 패턴과 non-blocking IO를 사용해 서비스에 필요한 쓰레드의 수를 줄이는 것이 NIO 의 핵심입니다. 즉 처리 가능한 접속 수를 늘리는 것이지요.

댓글 달기

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