> 백엔드 개발 > Golang > gRPC 서버에서 모든 클라이언트로 이벤트를 브로드캐스트하는 방법은 무엇입니까?

gRPC 서버에서 모든 클라이언트로 이벤트를 브로드캐스트하는 방법은 무엇입니까?

Mary-Kate Olsen
풀어 주다: 2024-11-02 06:00:30
원래의
863명이 탐색했습니다.

How to Broadcast Events from a gRPC Server to All Clients?

서버에서 클라이언트로 gRPC 이벤트 브로드캐스트

gRPC에서는 사용자가 클라이언트로 서버에 연결할 때 브로드캐스팅하는 것이 중요합니다. 이 이벤트는 연결된 모든 클라이언트에게 전달됩니다. 이를 달성하기 위해 서버측 관찰자 또는 장기 폴링 접근 방식을 활용할 수 있습니다.

서버측 관찰자

서버는 연결된 목록을 유지할 수 있습니다. 클라이언트. 새 클라이언트가 연결되면 해당 스트림이 목록에 추가됩니다. 이벤트를 브로드캐스트하기 위해 서버는 단순히 목록을 반복하고 이벤트를 각 스트림으로 보냅니다. 그러나 이 접근 방식을 사용하려면 서버가 연결된 클라이언트를 추적하고 스트림 구독을 관리해야 하므로 복잡해질 수 있습니다.

장기 폴링 접근 방식

장기 폴링은 대체 솔루션을 제공합니다. . 각 클라이언트는 서버와 함께 수명이 긴 스트림을 설정합니다. 클라이언트는 서버에 요청을 보내고 응답을 기다립니다. 서버는 이벤트가 발생할 때까지 요청을 보류합니다. 이벤트가 발생하면 서버는 클라이언트에 응답하여 긴 폴링 호출을 트리거하여 반환합니다.

다음은 긴 폴링을 사용하는 예입니다.

<code class="python"># Server-side code
class UpdaterServer:
    def post_update(self, update):
        with self.condition:
            self.updates.append(update)
            self.condition.notify_all()

    def GetUpdates(self, req, context):
        while self.updates[req.last_received_update + 1:] == []:
            self.condition.wait()
        new_updates = self.updates[req.last_received_update + 1:]
        response = GetUpdatesResponse()
        for update in new_updates:
            response.updates.add().CopyFrom(update)
        response.update_index = req.last_received_update + len(new_updates)
        return response

# Client-side code
request = GetUpdatesRequest()
request.last_received_update = -1
while True:
    try:
        response = stub.GetUpdates(request, timeout=60*10)
        handle_updates(response.updates)
        request.last_received_update = response.update_index
    except grpc.FutureTimeoutError:
        pass</code>
로그인 후 복사

새 이벤트가 발생하면 서버는 대기 중인 모든 클라이언트에게 알리는 post_update()를 호출합니다. 그러면 클라이언트의 장기 폴링 호출이 업데이트된 정보와 함께 돌아옵니다.

위 내용은 gRPC 서버에서 모든 클라이언트로 이벤트를 브로드캐스트하는 방법은 무엇입니까?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!

원천:php.cn
본 웹사이트의 성명
본 글의 내용은 네티즌들의 자발적인 기여로 작성되었으며, 저작권은 원저작자에게 있습니다. 본 사이트는 이에 상응하는 법적 책임을 지지 않습니다. 표절이나 침해가 의심되는 콘텐츠를 발견한 경우 admin@php.cn으로 문의하세요.
저자별 최신 기사
인기 튜토리얼
더>
최신 다운로드
더>
웹 효과
웹사이트 소스 코드
웹사이트 자료
프론트엔드 템플릿