2011-11-01 4 views
11

애플리케이션을 작성하기 전에 단일 node.js 인스턴스 (express 및 (socket.io 또는 nowjs))가 아닌 경우 수행 할 작업을 알아야합니다. 더 이상 충분하지 않습니다.Node : Scale socket.io/nowjs - 다른 인스턴스에서 확장 가능

시간이 오기 전까지는 배율을 신경 쓰지 말고 응용 프로그램을 개발하고 문제가 생기지 않도록 할 수 있습니다. socket.io 또는 nowjs를 여러 배로 쉽게 확장 할 수 없으므로 인스턴스.

최근에 socket.io가 Redis를 사용하여 확장하는 방법을 지원한다는 것을 읽었습니다. Nowjs는 socket.io에 빌드됩니다 - 같은 방식으로 작동합니까? nowjs.org에서 "NowJS의 분산 버전"이 개발 중이며 비용이 많이 듭니다.

답변

14

노드를 확장해야하는 경우 사람들이 일반적으로 시작하는 첫 번째 단계는로드 밸런서를 여러 노드 인스턴스 앞에 배치하는 것입니다. 오늘이 표준은 nginx입니다.하지만 최근에 나온 노드 밸런서 '탄력성'을 확인하고 싶습니다. 여기에 여러 노드 인스턴스를 관리 할 nginx를 리버스 프록시를 사용하는 사람의 예입니다 : 당신이 언급

Node.js + Nginx - What now?

두 번째 것은 socket.io/nowjs입니다. 이러한 프레임 워크를 사용하는 방법에 따라 여러 개의 node.js 인스턴스를 사용하는 클라이언트간에 컨텍스트를 공유하려는 상황이 발생할 수 있습니다. 이 경우 redis와 같은 영구 저장소를 사용하여 노드 인스턴스 사이의 간격을 메우는 것이 좋습니다.

How to reuse redis connection in socket.io?

희망이 충분한 정보와, 당신이 시작하는 당신이 어떤 질문이 있으면 알려 주시기을 읽고 예를 들면 다음과 같습니다이다.

해피 코딩!

+0

감사합니다. redis로 nowjs를 사용할 수 있는지 알고 계십니까? – Eliasdx

+0

물론 다른 용도의 두 가지 완전히 다른 기술 일 수 있습니다. Nowjs는 socket.io와 유사한 지속적인 서버 - 클라이언트 연결 기능을 제공 할 것입니다. 이것은 서버 대 클라이언트 메시징, 클라이언트 브로드 캐스트 등과 같은 것들에 유용합니다. 전형적인 예는 chatroom을 구축하는 것입니다. Redis는 백엔드 데이터 저장소로 더 많이 사용됩니다. 키 - 값 쌍 저장, pubsub 등과 같은 작업을 수행 할 수 있습니다. 노드 외부에서 별도의 프로세스 (또는 별도의 시스템)로 존재하기 때문에 브리징에 유용합니다. 여러 서버. –

1

'Socket.IO 스케일링'을 또 다른 유용한 링크 안정 버전 인 nginx 1.0.x는 http/1.1 연결 (웹 소켓과 함께 작동하는 socket.io를 만들기 위해 필요함)의 프록 싱을 지원하지 않습니다. 여기에 설명 된 해결 방법이 있습니다 : http://www.letseehere.com/reverse-proxy-web-sockets을 사용하거나 대신 https://github.com/nodejitsu/node-http-proxy 같은 것을 사용하십시오. nodejitsu의 사람들은이를 지원해야한다고 말합니다.