PGR21.com
- PGR21 관련된 질문 및 건의는 [건의 게시판]을 이용바랍니다.
- (2013년 3월 이전) 오래된 질문글은 [이전 질문 게시판]에 있습니다.
통합 규정을 준수해 주십시오. (2015.12.25.)
Date 2016/04/12 12:30:44
Name 몽유도원
Subject [질문] 인터넷상에서 채팅구현. 이런 방법은 서버에 얼마나 과부하걸릴까요?
웹소켓등을 이용한 방식은 아니고 매우 원초적이고 무식한 방법인데

1. 유저들이 채팅방에 입장한다.
2. A가 텍스트를 입력하고 엔터를 치면
3. 나머지 유저들은 해당 화면이 자동적으로 새로고침되면서 A가 입력한 채팅을 볼 수 있다.

이런 방식은 서버에 얼마나 무식하고 비효율적으로 과부하를 줄까요?

통합규정 1.3 이용안내 인용

"Pgr은 '명문화된 삭제규정'이 반드시 필요하지 않은 분을 환영합니다.
법 없이도 사는 사람, 남에게 상처를 주지 않으면서 같이 이야기 나눌 수 있는 분이면 좋겠습니다."
-안군-
16/04/12 12:35
수정 아이콘
일단, 한 유저가 입력을 하는 시점을 다른 유저들이 (웹브라우저에서) 알아챌 수 있는 방법이 웹소켓같은걸 안쓰고는 없습니다.
그러니, 주기적으로 자동갱신을 하거나(PGR의 불판창처럼) 해야 하는데, 생각보다 그렇게 비효율적일 것 까지는 없을 것 같습니다.
백엔드를 어떻게 짜느냐에 따라서 엄청난 차이가 생기겠네요.
16/04/12 12:53
수정 아이콘
아무 일 없이 자동적으로 새로고침은 불가능하구요. 새로고침 정보를 받아야 하는데 그게 웹소켓이나 Server side push로 구현되는 방식이고..
주기적으로 채팅을 땡겨와야 하는데 long-polling을 이용하면 효율적으로 처리할 수 있고, 그냥 polling을 해도 polling interval을 적당한 숫자로 잘 잡으면 그렇게 엄청 무식하거나 엄청 비효율적이진 않습니다.
정지연
16/04/12 13:30
수정 아이콘
소켓이없이 웹페이지로 구현한다면 클라이언트가 주기적으로 서버로 request 를 보내면 서버에서 새로 읽어갈 정보가 있는지 체크하고 결과를 보내주는 식으로 해야 할텐데..
처음부터 이것만을 위한 서버를 별도로 구축하고 참여자수, 주기를 조정한다면 그리 큰 부담은 아닐거라 봅니다.. 다만 원래 다른 목적이 있는 시스템에 곁다리로 이런걸 끼운다면 이경우는 배보다 배꼽이 더 커지는 상황이겠죠..
16/04/12 13:48
수정 아이콘
동시 접속자 수가 가장 중요한 factor 입니다.
랜덤여신
16/04/12 14:04
수정 아이콘
우선, 윗분들이 말씀하신 것처럼 '자동적으로' 새로고침되는 방법은 없습니다. 웹 소켓 없이는 새 메시지가 발생한 시점을 알 수 없으니까요. 따라서 '주기적으로' 새로고침하는 방법을 써야 하겠죠.

아~~주 오래 전 인터넷 채팅 서비스들은 실제로 이렇게 동작했습니다. 90년대 후반에 대략 5초에 한 번씩 새로고침하는 웹 채팅 사이트를 본 적이 있습니다. 내 채팅이 상대에게 바로 바로 안 보이긴 하지만 크게 답답한 수준은 아니었던 걸로 기억합니다.

이런 방식은 메시지량이 적으면 적을수록 낭비가 심할 것입니다. 아무 대화가 없어도 5초마다 새로고침해야 하니까요. 그러나 특정 한계 이상으로 부하가 늘어나지도 않을 겁니다. 아무리 대화가 많아도 5초에 한 번씩만 새로고침하니까요.
Lightsaber
16/04/12 16:29
수정 아이콘
무식하고 비효율적인 방식이긴 하지만 쓰는 사람이 얼마 없다면 문제될 것도 없죠.
옛날에 PERL로 짠 .CGI 파일들로 웹사이트 만들던 시절엔 그렇게들도 제법 구현했었죠.

그런데 굳이 그렇게 비효율적으로 만들어야 할 필요야 요즘엔 그다지 없죠. 웹소켓을 이용한 웹사이트 채팅 구현 예제는 어지간한 언어로 다 소스를 쉽게 찾을 수 있고, 이런 채팅 부분만을 제공해주는 서비스들도 있어서 웹마스터가 채팅 API를 자신의 홈페이지에 삽입해 넣는 식으로 쉽게 넘어갈 수도 있죠.

제 생각에는 비효율적인 방식이긴 해도 어지간히 접속자 수가 많지 않은 바에는 그렇게 큰 부담 없이 운용할 수는 있지 않을까 싶습니다.
한 달에 3만원쯤 주고 임대하는 가상서버들도 httpd에 있는 ./ab 테스트로 DB에서 자료 불러오는 것까지 포함해서 갈궈보면 500명이 동시접속으로 밀고 들어온다고 쳐도 잘 버티던데, 5초에 한 번씩 텍스트만 출력되는 부분을 리프레시하는 것 정도야...
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
81288 [질문] 아이스 아메리카노만 마시면 신호가 옵니다 [14] 피스~4184 16/04/12 4184
81287 [질문] 너무 심심해요 할 게임이 필요합니다. [22] lenakim3152 16/04/12 3152
81286 [질문] 어머니랑 같이 볼만한 영화 있을까요? [9] 파랑파랑1924 16/04/12 1924
81285 [질문] 삼성 스마트tv 녹화 기능이 있는건가요 없는건가요? [5] AminG9391 16/04/12 9391
81284 [질문] 노트북 질문입니다 !! 곰비1203 16/04/12 1203
81283 [질문] 중학교 2학년 수학문제 질문입니다. [10] rnsr1895 16/04/12 1895
81282 [질문] 현직 미국입니다. 체크카드 결제할 때 문의드려요 [8] 유노윤하2460 16/04/12 2460
81281 [질문] 담배 하루 한갑 이상 피우는 흡연자가 금연하는 난이도는 어느 정도인가요? [18] 오스카8489 16/04/12 8489
81279 [질문] 인천공항을 처음으로 갑니다. 질문좀 드려요 [32] 키키모하3166 16/04/12 3166
81278 [질문] 프로게이머들의 징크스나 습관 같은걸 아시는 분 있나요? [10] 어바웃타임2649 16/04/12 2649
81277 [질문] 인터넷상에서 채팅구현. 이런 방법은 서버에 얼마나 과부하걸릴까요? [6] 몽유도원3786 16/04/12 3786
81276 [질문] 스마트폰 성능써먹을 방법...? [5] 자유형다람쥐1843 16/04/12 1843
81275 [질문] 우고스 란 회사 아시는분 계신가요? Dante3610 16/04/12 3610
81274 [질문] 공기업 들어가고 싶은데요.. [5] 비러브2774 16/04/12 2774
81273 [질문] 왁스,스프레이 추천부탁드립니다 [14] ...And justice2535 16/04/12 2535
81272 [질문] 윈도우7에서 자꾸 윈도우 10으로 업그레이드 되는데 방지하는 방법 없을까요? [2] Red Key2443 16/04/12 2443
81271 [질문] 부산에 토마토 농장 괜찮은 곳 있을까요? (대저) [1] [fOr]-FuRy1486 16/04/12 1486
81270 [질문] 영어공부용 미드 프렌즈 vs 모던패밀리 어떤게 나을까요? [11] 삭제됨8659 16/04/12 8659
81269 [질문] 중고 카메라 가격 질문입니다. [8] 로각좁1841 16/04/12 1841
81268 [질문] 혹시 시원한 베개 있나요..??? [6] 춥다춥스4179 16/04/12 4179
81267 [질문] 팟플레이어로 음악 재생시 다음 곡으로 넘어가지 않는 문제 [3] 1일3똥6181 16/04/12 6181
81266 [질문] 핸드폰 구입시 판매자의 계약서 대리서명에 관한 질문입니다. [3] 뽐뽀미4092 16/04/12 4092
81265 [질문] 9급공무원시험공부질문입니다 [13] stromae5457 16/04/12 5457
목록 이전 다음
댓글

+ : 최근 1시간내에 달린 댓글
+ : 최근 2시간내에 달린 댓글
맨 위로