WebSockets로 영구 연결 만들기

WebSockets를 사용하여 클라이언트(휴대기기나 컴퓨터 등)에서 App Engine 인스턴스로의 영구 연결을 만들 수 있습니다. 개방형 연결은 언제든지 클라이언트와 서버 간의 양방향 데이터 교환을 허용함으로써 지연 시간을 단축하고 리소스를 더 효율적으로 사용할 수 있도록 합니다.

WebSockets

RFC 6455에 정의된 WebSockets 프로토콜은 클라이언트와 서버 간의 전이중 통신 채널을 제공합니다. 채널은 'upgrade' 헤더가 있는 HTTP(S) 요청으로 시작됩니다.

WebSockets의 일반적인 사용 사례는 다음과 같습니다.

  • 소셜 미디어 피드, 스포츠 점수, 뉴스, 주가 등의 실시간 이벤트 업데이트
  • 소프트웨어, 콘텐츠 업데이트 등의 사용자 알림
  • 채팅 애플리케이션
  • 협업 편집 도구
  • 멀티플레이어 게임

WebSockets는 추가적인 설정 없이 애플리케이션에서 항상 사용할 수 있습니다. 설정된 WebSockets 연결은 1시간 후에 타임아웃됩니다.

WebSockets로 샘플 애플리케이션 실행

먼저 App Engine에서 Python용 'Hello, World!'의 안내에 따라 환경과 프로젝트를 설정하여 App Engine Python 앱의 구조화 방식에 대해 알아보세요.

샘플 앱 복제

샘플 앱을 로컬 머신에 복사하고 websockets 디렉터리로 이동합니다.

git clone https://github.com/GoogleCloudPlatform/python-docs-samples
cd python-docs-samples/appengine/flexible/websockets/

로컬에서 샘플 실행

로컬에서 실행하려면 Gunicornflask_socket 작업자와 함께 사용해야 합니다.

$ gunicorn -b 127.0.0.1:8080 -k flask_sockets.worker main:app

App Engine에서 샘플 배포 및 실행

애플리케이션을 App Engine 가변형 환경에 배포하려면 app.yaml이 위치한 디렉터리에서 다음 명령어를 실행합니다.

gcloud app deploy

그런 다음에 브라우저에서 https://[YOUR_PROJECT_ID].appspot.com/으로 이동할 수 있습니다.

세션 어피니티

모든 클라이언트가 WebSockets를 지원하는 것은 아닙니다. 이를 해결하기 위해 많은 애플리케이션은 WebSockets를 지원하지 않는 클라이언트에서 http 장기 폴링으로 대체하는 socket.io와 같은 라이브러리를 사용합니다.

일반적으로 App Engine은 요청을 사용 가능한 인스턴스 간에 균등하게 분배합니다. 하지만 http 장기 폴링을 사용할 때는 특정 사용자의 여러 순차적 요청이 동일 인스턴스에 전달되어야 합니다.

App Engine이 동일 사용자의 요청을 동일 인스턴스에 보낼 수 있도록 하기 위해 세션 어피니티를 사용 설정할 수 있습니다. 그러면 App Engine이 쿠키를 조사하여 동일 사용자가 보낸 요청을 식별하고 해당 요청을 동일 인스턴스에 라우팅합니다.

App Engine에서 세션 어피니티는 최선의 방식으로 실행됩니다. 앱을 개발할 때는 항상 세션 어피니티가 보장되지 않는다고 가정해야 합니다. 다음과 같은 시나리오에서 클라이언트가 대상 인스턴스와의 어피니티를 잃을 수 있습니다.

  • 애플리케이션을 제공하는 인스턴스를 App Engine 자동 확장 처리가 추가하거나 삭제할 수 있습니다. 이 애플리케이션은 부하를 재할당할 수 있으며, 대상 인스턴스가 이동할 수도 있습니다. 이 위험을 최소화하기 위해 예상 부하를 처리하기 위한 최소 인스턴스 수를 설정해야 합니다.
  • 대상 인스턴스가 상태 확인에 실패할 경우 App Engine은 세션을 정상 인스턴스로 이동합니다.
  • 유지관리 또는 소프트웨어 업데이트를 위해 인스턴스가 재부팅될 때 세션 어피니티가 손실됩니다. App Engine 가변형 환경 VM 인스턴스는 매주 다시 시작됩니다.

세션 어피니티가 보장되지 않기 때문에 연결이 끊겼을 때 HTTP 장기 폴링으로 대체할 수 있는 socket.io 및 기타 라이브러리의 능력을 활용해야 합니다. 상태 저장 애플리케이션을 빌드하는 데 세션 어피니티를 사용해서는 안 됩니다.

세션 어피니티 사용 설정 및 중지

기본적으로 세션 어피니티는 모든 App Engine 애플리케이션에 대해 비활성화되어 있습니다. 세션 어피니티는 애플리케이션의 버전 수준에서 설정되며 배포 시 사용 설정되거나 중지될 수 있습니다.

App Engine 버전의 세션 어피니티를 사용 설정하려면 다음 항목을 app.yaml 파일에 추가하세요.

network:
  session_affinity: true

업데이트된 app.yaml과 함께 버전이 배포되면 새 요청이 동일 인스턴스에서 제공되기 시작합니다. 단, 해당 인스턴스가 사용 가능한 상태여야 합니다.

세션 어피니티를 사용 중지하려면 app.yaml 파일에서 항목을 삭제하거나 값을 false로 설정합니다.

network:
  session_affinity: false
이 페이지가 도움이 되었나요? 평가를 부탁드립니다.

다음에 대한 의견 보내기...

Python 문서용 App Engine 가변형 환경