ストリームが移行元データベースから移行先にデータを転送する際に問題が発生すると、ストリームは Failed 状態または Failed permanently 状態になることがあります。どちらの場合も、問題を解決できます。
ストリームのトラブルシューティング
Google Cloud コンソールの [ストリーム] ページに移動します。
画面右上にある列の表示オプション アイコンをクリックします。アイコンは縦に並んだ 3 つの列として表示されます。
選択されていない場合は、[ステータス] チェックボックスをオンにして、[OK] をクリックします。Datastream には次のステータスが表示されます。
Failed:Runningストリームで発生したエラー。このようなエラーは、ストリームがまだアクティブであるか、実行の試みがくり返されていることを意味します。Failed permanently: 実行を継続できないストリームの場合。このようなエラーでは、データが失われる可能性があります。
トラブルシューティングするストリームをクリックします。ストリームに関連するエラーは、[ストリームの詳細] ページに表示されます。
たとえば、Datastream がソース データベースに接続できない場合、指定された認証情報ではデータソースに接続できませんというエラーページが表示されます。
エラーを解決します。ストリームまたは接続プロファイルのいずれかのエラーを解決できます。
たとえば、ストリームのソース データ オブジェクトまたは宛先構成情報のいずれかにエラーが関連付けられている場合は、ストリームを変更します。
ストリームの接続情報にエラーが関連付けられている場合は、ストリームで使用されている接続プロファイルのソース データベースまたは宛先の構成情報を更新します。
Failedストリームを修正して自動的に再開できるようにするか、Failed permanentlyストリームを復元します。
ストリームを復元する
ストリームを復元する際に最初に試すのは、現在の位置から復元することです。ストリーム復元オプションの詳細については、ストリーム復元の概要をご覧ください。
現在の位置からのストリームの復元に失敗した場合は、次の手順をお試しください。
- 宛先で影響を受けるテーブルを削除または切り捨てます。ストリームがダウンしていた間に、Datastream がいくつかの
DELETEイベントを見逃している可能性があります。バックフィルの実行前にテーブルを切り捨てないと、DELETEイベントを復元できません。 - ストリームを最新の位置から復元します。PostgreSQL の場合は、レプリケーション スロットを再作成するか、新しいレプリケーション スロットを作成します。
- ストリームが実行されたら、バックフィルをトリガーしてすべての履歴データを復元します。バックフィルのトリガー方法については、バックフィルを開始するをご覧ください。
次のステップ
- ストリームの詳細については、ストリームのライフサイクルをご覧ください。
- ストリームを変更する方法については、ストリームを変更するをご覧ください。
- 失敗したストリームを復元する方法については、ストリームを復元するをご覧ください。