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초에 한 번씩 텍스트만 출력되는 부분을 리프레시하는 것 정도야...
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
81278 [질문] 프로게이머들의 징크스나 습관 같은걸 아시는 분 있나요? [10] 어바웃타임2864 16/04/12 2864
81277 [질문] 인터넷상에서 채팅구현. 이런 방법은 서버에 얼마나 과부하걸릴까요? [6] 몽유도원4027 16/04/12 4027
81276 [질문] 스마트폰 성능써먹을 방법...? [5] 자유형다람쥐1956 16/04/12 1956
81275 [질문] 우고스 란 회사 아시는분 계신가요? Dante3681 16/04/12 3681
81274 [질문] 공기업 들어가고 싶은데요.. [5] 비러브2858 16/04/12 2858
81273 [질문] 왁스,스프레이 추천부탁드립니다 [14] ...And justice2763 16/04/12 2763
81272 [질문] 윈도우7에서 자꾸 윈도우 10으로 업그레이드 되는데 방지하는 방법 없을까요? [2] Red Key2582 16/04/12 2582
81271 [질문] 부산에 토마토 농장 괜찮은 곳 있을까요? (대저) [1] [fOr]-FuRy1648 16/04/12 1648
81270 [질문] 영어공부용 미드 프렌즈 vs 모던패밀리 어떤게 나을까요? [11] 삭제됨8807 16/04/12 8807
81269 [질문] 중고 카메라 가격 질문입니다. [8] 로각좁1970 16/04/12 1970
81268 [질문] 혹시 시원한 베개 있나요..??? [6] 춥다춥스4251 16/04/12 4251
81267 [질문] 팟플레이어로 음악 재생시 다음 곡으로 넘어가지 않는 문제 [3] 1일3똥6393 16/04/12 6393
81266 [질문] 핸드폰 구입시 판매자의 계약서 대리서명에 관한 질문입니다. [3] 뽐뽀미4260 16/04/12 4260
81265 [질문] 9급공무원시험공부질문입니다 [13] stromae5600 16/04/12 5600
81264 [질문] 이게 선게용인지 질게용인지 몰라서 일단 질게에 적습니다. [6] EZrock1712 16/04/12 1712
81263 [질문] 모 선수 강간혐의 항소 결과 아시는분 계신가요? [4] 삭제됨3343 16/04/11 3343
81262 [질문] 인터넷이 기가콤팩트 상품인데 와이파이 다운로드 속도가 20M/s면 괜찮은 수준인가요? [2] Red Key4025 16/04/11 4025
81261 [질문] USB 부팅이 안됩니다. [3] 불꽃이대세1473 16/04/11 1473
81260 [질문] 더뉴k3 구매하셨던 분 계신가요? [1] resgestae1480 16/04/11 1480
81259 [질문] 허리디스크 질문입니다 [1] 해피바스1501 16/04/11 1501
81258 [질문] PGR21에서만 유독 '나이브' 이 표현 쓰시는 분이 많지 않나요? [47] 쿤데라5240 16/04/11 5240
81257 [질문] 투표할때 지역구에 무효표 던지고 온게 욕먹을 일인가요? [30] 커피는레쓰비3497 16/04/11 3497
81256 [질문] 수원역 근처에 피부과 추천해주실만한곳 있나요? [4] 사신군3557 16/04/11 3557
목록 이전 다음
댓글

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