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