Go 스크립트에서 RABBITMQ 교착 상태 감지 조사
streadway/amqp 라이브러리를 사용하는 Go 소비자 스크립트가 응답하지 않는 문제가 사용자에게 발생했습니다. RabbitMQ 서버가 종료되고 서버를 다시 시작해도 메시지가 전달되지 않은 상태로 남아 있습니다. 이는 다음과 같은 질문을 던집니다. 어떻게 죽은 소비자 연결을 감지하고 소비자 스크립트를 다시 연결하거나 종료할 수 있습니까?
이를 해독하기 위해 라이브러리의 하트비트 메커니즘을 조사합니다. 하트비트 간격은 기본적으로 10초로 설정됩니다. 그러나 이 하트비트 기능은 API에 노출되지 않으므로 명시적으로 사용할 수 없습니다.
대신 채널 신호 전송을 반환하는 amqp.Connection의 NotifyClose() 메서드를 활용하는 것이 좋습니다. 프로토콜 오류. 지속적으로 다시 연결하는 루프를 생성함으로써 소비자가 활성 상태를 유지하고 서버 변경 사항에 응답하도록 할 수 있습니다.
이 접근 방식의 구현 예는 다음과 같습니다.
for { // Establish the connection conn, err := amqp.Dial("amqp://guest:guest@localhost:5672/") if err != nil { // Handle the error and retry } // Register for connection closure notifications notify := conn.NotifyClose(make(chan *amqp.Error)) // Create a channel and consumer ch, err := conn.Channel() if err != nil { // Handle the error } msgs, err := ch.Consume(...) for { select { case err := <-notify: // Handle the connection error and reconnect case d := <-msgs: // Process the message } } }
이를 통합하여 오류 처리 메커니즘을 통해 당사의 소비자 스크립트는 연결 중단을 적절하게 처리하고 동적 서버 환경에서도 지속적인 메시지 전달을 보장할 수 있습니다.
위 내용은 Go 스크립트는 RabbitMQ 교착 상태를 어떻게 감지하고 복구할 수 있나요?의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!