nginx 프록시 소켓.io 서비스의 함정을 해결하는 방법
nginx는 두 개의 소켓.io 서버에 대한 프록시 역할을 합니다. Socket.io의 작업 모드는 폴링 및 websocket으로 업그레이드 중입니다
Phenomenon
nginx를 통해 서비스를 요청하면 400 오류가 대량으로 나타나는 경우도 있습니다. 때로는 websocket으로 업그레이드할 수도 있고, 계속 오류를 보고하는 경우도 있습니다. 하지만 ip+端口
를 통해 직접 접속하면 100% 성공합니다.
Analytics
sid
sid가 우리 문제의 핵심입니다. 처음 연결을 생성할 때(폴링 모드는 긴 연결을 시뮬레이션함) 클라이언트는 다음과 같은 요청을 시작합니다.
https://***/?eio=3&transport=polling&t=1540820717277-0
서버에서 수신 An 개체가 생성되어 연결에 바인딩되며 세션을 표시하기 위해 sid(세션 ID)가 반환됩니다. 세션은 무엇을 의미합니까? 세션은 일련의 상호 작용이며 이러한 상호 작용은 서로 관련되어 있습니다. 우리 시나리오에서는 다음 http 요청이 오면 이전에 이론에 바인딩된 긴 연결을 찾아야 합니다(아직 여기에 없음). 이론적으로는 websocket입니다). 우리는 http 요청이 상태 비저장(stateless)이고 각 요청이 독립적이라는 것을 알고 있습니다. 그래서 소켓.io는 이를 위해 sid를 도입했습니다. 요청을 받은 후 서버는 sid를 생성합니다. 응답을 살펴보세요.
코드 복사 코드는 다음과 같습니다:
{"sid":"eogal3frqlptoalp5est","upgrades":["websocket"], "pinginterval":8000," pingtimeout":10000}
모든 후속 요청은 이 SID를 가져와야 하며 웹소켓 요청에 대한 연결 설정도 예외는 아닙니다. 따라서 sid는 폴링을 웹소켓으로 업그레이드하고 폴링하는 데 핵심이 됩니다. 이후의 요청은
https://***/?eio=3&transport=polling&t=1540820717314-1&sid=eogal3frqlptoalp5est or wss://***/?eio=3&transport=websocket&t=1540820717314-1&sid=eogal3frqlptoalp5est
와 유사합니다. 그러면 질문은 요청의 sid가 서버에서 생성되지 않으면 어떻게 됩니까? 서버는 이를 인식하지 못하고 400을 반환하고
invalid sid
라고 알려줍니다. 이것이 우리가 직면한 문제입니다. nginx의 기본 로드 밸런싱 전략은 폴링이므로 요청이 SID를 생성하지 않은 시스템에 도달할 수 있습니다. 올라가면 이때 400을 받게 됩니다. 운이 좋으면 웹소켓 연결이 설정될 때까지 지속될 수도 있습니다.
솔루션
다음에 두 가지 솔루션이 제안됩니다
nginx의 로드 밸런싱은 ip_hash를 사용하여 모든 클라이언트 요청이 하나의 서버로 이동하도록 보장합니다.
-
폴링 모드를 사용하지 말고 websocket만 사용하세요
두 옵션 모두 장단점이 있습니다. 두 번째로 확실한 점은 웹소켓을 지원하지 않는 오래된 브라우저와 클라이언트는 작동하지 않는다는 것입니다. 첫 번째 유형의 문제는 더 깊이 숨겨져 있습니다. 이때, ip_hash 정책의 모드가 변경되고, 마이크로서비스의 경우 확장 및 축소가 매우 불가능해집니다. 빈번한 작업(특히 제품이 개발 단계에 있는 경우)에서 이러한 종류의 손실이 있는 팽창 및 수축은 용납될 수 없습니다.
위 내용은 nginx 프록시 소켓.io 서비스의 함정을 해결하는 방법의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

핫 AI 도구

Undresser.AI Undress
사실적인 누드 사진을 만들기 위한 AI 기반 앱

AI Clothes Remover
사진에서 옷을 제거하는 온라인 AI 도구입니다.

Undress AI Tool
무료로 이미지를 벗다

Clothoff.io
AI 옷 제거제

Video Face Swap
완전히 무료인 AI 얼굴 교환 도구를 사용하여 모든 비디오의 얼굴을 쉽게 바꾸세요!

인기 기사

뜨거운 도구

메모장++7.3.1
사용하기 쉬운 무료 코드 편집기

SublimeText3 중국어 버전
중국어 버전, 사용하기 매우 쉽습니다.

스튜디오 13.0.1 보내기
강력한 PHP 통합 개발 환경

드림위버 CS6
시각적 웹 개발 도구

SublimeText3 Mac 버전
신 수준의 코드 편집 소프트웨어(SublimeText3)

뜨거운 주제











클라우드 서버에서 nginx 도메인 이름을 구성하는 방법 : 클라우드 서버의 공개 IP 주소를 가리키는 레코드를 만듭니다. Nginx 구성 파일에 가상 호스트 블록을 추가하여 청취 포트, 도메인 이름 및 웹 사이트 루트 디렉토리를 지정합니다. Nginx를 다시 시작하여 변경 사항을 적용하십시오. 도메인 이름 테스트 구성에 액세스하십시오. 기타 참고 : HTTPS를 활성화하려면 SSL 인증서를 설치하고 방화벽에서 포트 80 트래픽을 허용하고 DNS 해상도가 적용되기를 기다립니다.

단계를 따르면 Docker 컨테이너 이름을 쿼리 할 수 있습니다. 모든 컨테이너 (Docker PS)를 나열하십시오. 컨테이너 목록을 필터링합니다 (GREP 명령 사용). 컨테이너 이름 ( "이름"열에 위치)을 가져옵니다.

nginx가 시작되었는지 확인하는 방법 : 1. 명령 줄을 사용하십시오 : SystemCTL 상태 nginx (linux/unix), netstat -ano | Findstr 80 (Windows); 2. 포트 80이 열려 있는지 확인하십시오. 3. 시스템 로그에서 nginx 시작 메시지를 확인하십시오. 4. Nagios, Zabbix 및 Icinga와 같은 타사 도구를 사용하십시오.

Windows에서 Nginx를 구성하는 방법은 무엇입니까? nginx를 설치하고 가상 호스트 구성을 만듭니다. 기본 구성 파일을 수정하고 가상 호스트 구성을 포함하십시오. 시작 또는 새로 고침 Nginx. 구성을 테스트하고 웹 사이트를보십시오. SSL을 선택적으로 활성화하고 SSL 인증서를 구성하십시오. 포트 80 및 443 트래픽을 허용하도록 방화벽을 선택적으로 설정하십시오.

nginx 버전을 쿼리 할 수있는 메소드는 다음과 같습니다. nginx -v 명령을 사용하십시오. nginx.conf 파일에서 버전 지시문을 봅니다. nginx 오류 페이지를 열고 페이지 제목을 봅니다.

Nginx 서버를 시작하려면 다른 운영 체제에 따라 다른 단계가 필요합니다. Linux/Unix System : Nginx 패키지 설치 (예 : APT-Get 또는 Yum 사용). SystemCTL을 사용하여 nginx 서비스를 시작하십시오 (예 : Sudo SystemCtl start nginx). Windows 시스템 : Windows 바이너리 파일을 다운로드하여 설치합니다. nginx.exe 실행 파일을 사용하여 nginx를 시작하십시오 (예 : nginx.exe -c conf \ nginx.conf). 어떤 운영 체제를 사용하든 서버 IP에 액세스 할 수 있습니다.

Docker Container Startup 단계 : 컨테이너 이미지를 당기기 : "Docker Pull [Mirror Name]"을 실행하십시오. 컨테이너 생성 : "docker"[옵션] [미러 이름] [명령 및 매개 변수]를 사용하십시오. 컨테이너를 시작하십시오 : "Docker start [컨테이너 이름 또는 ID]"를 실행하십시오. 컨테이너 상태 확인 : 컨테이너가 "Docker PS"로 실행 중인지 확인하십시오.

Docker에서 컨테이너 만들기 : 1. 이미지를 당기기 : Docker Pull [Mirror Name] 2. 컨테이너 만들기 : Docker Run [옵션] [미러 이름] [명령] 3. 컨테이너 시작 : Docker Start [컨테이너 이름]
