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 中国語 Web サイトの他の関連記事を参照してください。