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초에 한 번씩 텍스트만 출력되는 부분을 리프레시하는 것 정도야...
목록 삭게로! 맨위로
번호 제목 이름 날짜 조회
81321 [질문] 갤럭시 S7 or 엣지 [17] 손금불산입2867 16/04/13 2867
81320 [질문] 선유도 공원에서 멀지 않은 맛집(식당, 까페) 추천 부탁드려요. [1] 미남주인1551 16/04/13 1551
81319 [질문] 자세(척추 등)교정하는 방송 알려주세요.(비타민 같은 느낌) [1] 파란무테1806 16/04/13 1806
81318 [질문] 27인치 플스 겸용 모니터 추천 부탁드립니다~ [3] 히스조커3313 16/04/13 3313
81317 [질문] 선거당일 선거 전화.. [2] 하나3290 16/04/13 3290
81316 [질문] 정품인데 윈10 프로 정품인증하라고 계속 뜨네요. 해결법? [4] will4708 16/04/13 4708
81314 [질문] 기내에 스프레이, 쉐이빙폼 들고 탈 수 있나요? [7] 2015년10월9일18652 16/04/13 18652
81312 [질문] 빅피처가 무슨 뜻인가요? [17] 하율이아빠27873 16/04/13 27873
81311 [질문] 컴퓨존에서 조립컴퓨터를 샀는데, 하드가 파티션이 나눠져있네요 [5] 마르키아르3450 16/04/13 3450
81310 [질문] 뉴질랜드 6박7일 어떻게 해야할까요? [10] Monte2018 16/04/13 2018
81309 [질문] 예비군훈련 주소지상 주소 말고 다른곳에서 받는 방법 없을가요? [13] 도깽이4207 16/04/13 4207
81308 [질문] [수학] 등비급수 프랙탈문제입니다. [4] 선문선답8325 16/04/13 8325
81307 [질문] 진격의 거인 어떤 걸 봐야하나요? [2] 김여유2204 16/04/13 2204
81306 [질문] 일본 야당들은 왜이렇게 처참한가요? [15] 삭제됨4226 16/04/13 4226
81305 [질문] 알바 주휴수당은 정확히 계산이 어떻게 되나요?? [1] 말년행보관1940 16/04/13 1940
81304 [질문] Coolnovo 폰트 어떻게 바꾸나요? Apink초롱1158 16/04/13 1158
81303 [질문] 이번 타효니 선수 우승 기념 투기장 입장권 질문드립니다 [4] PENTAX1827 16/04/12 1827
81302 [질문] 컴알못 질문드립니다 [4] psiloveyou1519 16/04/12 1519
81301 [질문] 청년층(20-30대) 투표율 낮은 게 사실이라면 이유가 있을지요...? [36] nexon4571 16/04/12 4571
81300 [질문] [스타1] 2:2 헌터,무한 전략좀 알려주세요 [8] 냠냠이3855 16/04/12 3855
81299 [질문] 중고 카메라 가격 질문입니다.2번째 [7] 로각좁1401 16/04/12 1401
81298 [질문] 선거일에 대학교도서관 문 열까요? [16] ohmylove3093 16/04/12 3093
81297 [질문] 미러리스 카메라 렌즈 추천 좀 부탁드립니다. [3] journey211883 16/04/12 1883
목록 이전 다음
댓글

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