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초에 한 번씩 텍스트만 출력되는 부분을 리프레시하는 것 정도야...
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
81285 [질문] 삼성 스마트tv 녹화 기능이 있는건가요 없는건가요? [5] AminG9507 16/04/12 9507
81284 [질문] 노트북 질문입니다 !! 곰비1341 16/04/12 1341
81283 [질문] 중학교 2학년 수학문제 질문입니다. [10] rnsr1985 16/04/12 1985
81282 [질문] 현직 미국입니다. 체크카드 결제할 때 문의드려요 [8] 유노윤하2626 16/04/12 2626
81281 [질문] 담배 하루 한갑 이상 피우는 흡연자가 금연하는 난이도는 어느 정도인가요? [18] 오스카8664 16/04/12 8664
81279 [질문] 인천공항을 처음으로 갑니다. 질문좀 드려요 [32] 키키모하3353 16/04/12 3353
81278 [질문] 프로게이머들의 징크스나 습관 같은걸 아시는 분 있나요? [10] 어바웃타임2854 16/04/12 2854
81277 [질문] 인터넷상에서 채팅구현. 이런 방법은 서버에 얼마나 과부하걸릴까요? [6] 몽유도원4016 16/04/12 4016
81276 [질문] 스마트폰 성능써먹을 방법...? [5] 자유형다람쥐1950 16/04/12 1950
81275 [질문] 우고스 란 회사 아시는분 계신가요? Dante3678 16/04/12 3678
81274 [질문] 공기업 들어가고 싶은데요.. [5] 비러브2854 16/04/12 2854
81273 [질문] 왁스,스프레이 추천부탁드립니다 [14] ...And justice2755 16/04/12 2755
81272 [질문] 윈도우7에서 자꾸 윈도우 10으로 업그레이드 되는데 방지하는 방법 없을까요? [2] Red Key2579 16/04/12 2579
81271 [질문] 부산에 토마토 농장 괜찮은 곳 있을까요? (대저) [1] [fOr]-FuRy1643 16/04/12 1643
81270 [질문] 영어공부용 미드 프렌즈 vs 모던패밀리 어떤게 나을까요? [11] 삭제됨8799 16/04/12 8799
81269 [질문] 중고 카메라 가격 질문입니다. [8] 로각좁1967 16/04/12 1967
81268 [질문] 혹시 시원한 베개 있나요..??? [6] 춥다춥스4245 16/04/12 4245
81267 [질문] 팟플레이어로 음악 재생시 다음 곡으로 넘어가지 않는 문제 [3] 1일3똥6376 16/04/12 6376
81266 [질문] 핸드폰 구입시 판매자의 계약서 대리서명에 관한 질문입니다. [3] 뽐뽀미4251 16/04/12 4251
81265 [질문] 9급공무원시험공부질문입니다 [13] stromae5595 16/04/12 5595
81264 [질문] 이게 선게용인지 질게용인지 몰라서 일단 질게에 적습니다. [6] EZrock1710 16/04/12 1710
81263 [질문] 모 선수 강간혐의 항소 결과 아시는분 계신가요? [4] 삭제됨3339 16/04/11 3339
81262 [질문] 인터넷이 기가콤팩트 상품인데 와이파이 다운로드 속도가 20M/s면 괜찮은 수준인가요? [2] Red Key4021 16/04/11 4021
목록 이전 다음
댓글

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