總覽
選擇將資料庫遷移至 Cloud SQL 之前,請務必考量這個遷移情境的已知限制。
使用 PostgreSQL 資料庫做為來源時,已知限制包括:
pglogical
擴充功能不支援 PostgreSQL 12 以上版本的產生資料欄複製作業。透過標準 DDL 指令無法複製表格結構 (DDL),只能使用用於複製的
pglogical
擴充功能執行的指令。包括enum
類型的變更。舉例來說,
pglogical
提供pglogical.replicate_ddl_command
函式,可讓您在相同的時間點,於來源資料庫和副本中執行 DDL。在來源上執行這項指令的使用者必須已存在於副本中。如要複製新資料表的資料,請使用
pglogical.replication_set_add_table
指令,將新資料表新增至現有的複製集。如要進一步瞭解遷移作業進行期間的 DDL 複製作業,請參閱「遷移保真度」一節。
如果資料表沒有主鍵,資料庫移轉服務支援在變更資料擷取 (CDC) 階段遷移初始快照和
INSERT
陳述式。建議您手動遷移UPDATE
和DELETE
陳述式。資料庫移轉服務不會遷移具體化檢視區塊的資料,只會遷移檢視區塊結構定義。如要填入檢視區塊,請執行下列指令:
REFRESH MATERIALIZED VIEW view_name
。新 Cloud SQL 目的地的
SEQUENCE
狀態 (例如last_value
) 可能與來源的SEQUENCE
狀態不同。「
UNLOGGED
」和「TEMPORARY
」資料表不會也不可能複製。系統不支援 Large Object 資料類型。詳情請參閱「遷移保真度」一節。
只有 Cloud SQL 支援的 PostgreSQL 擴充功能和程序語言可以遷移。資料庫移轉服務不會遷移 Cloud SQL 不支援的擴充功能。這些擴充功能不會阻礙遷移作業,但為確保遷移過程順利,請確認物件或應用程���未參照任何不支援的擴充功能。建議您先從來源資料庫中移除這些擴充功能和參照,再繼續操作。
pg_cron
擴充功能 (或與擴充功能相關聯的任何cron
設定) 不會透過資料庫移轉服務遷移,但 Cloud SQL for PostgreSQL 目的地支援這類擴充功能。如果您在來源資料庫中使用pg_cron
擴充功能,可以在遷移完成後,在目的地執行個體上重新安裝。
資料庫移轉服務不支援從處於復原模式的讀取備用資源遷移。
資料庫移轉服務不支援套用 AWS SCT 擴充套件的 Amazon RDS 來源。
- 以 C 語言編寫的使用者定義函式無法遷移,但安裝 Cloud SQL 支援的擴充功能時,安裝在 PostgreSQL 資料庫中的函式除外。
如果來源資料庫中存在其他擴充功能和程序語言,或版本不受支援,測試或���動遷移工作時就會失敗。
遷移工作開始後新增的資料庫不會遷移。
- 使用資料庫移轉服務遷移資料時,無法選取特定表格或結構定義。
資料庫移轉服務會遷移所有資料表和結構定義,但下列項目除外:
- 資訊結構定義 (
information_schema
)。 - 開頭為
pg
的任何資料表,例如pg_catalog
。如要查看以pg
開頭的 PostgreSQL 目錄完整清單,請參閱 PostgreSQL 說明文件中的「PostgreSQL system catalogs」(PostgreSQL 系統目錄)。 - 使用者和使用者角色資訊不會遷移。
- 資訊結構定義 (
如果加密資料庫需要客戶自行管理加密金鑰才能解密,且資料庫移轉服務無法存取金鑰,則無法移轉資料庫。
不過,如果客戶資料是由
pgcrypto
擴充功能加密,則可使用資料庫移轉服務遷移資料 (因為 Cloud SQL 支援該擴充功能)。資料庫遷移服務也支援從加密的 Amazon Aurora 或 Amazon RDS 資料庫遷移資料,因為這些資料庫會在服務中以透明方式處理解密作業。詳情請參閱「Encrypting Amazon Aurora resources」和「Encrypting Amazon RDS resources」。
在移轉期間,目的地 Cloud SQL 資料庫可供寫入,因此可視需要套用 DDL 變更。請謹慎操作,不要變更資料庫設定或表格結構,否則可能會導致遷移程序中斷或影響資料完整性。
觸發條件的行為取決於設定方式。預設行為是不會觸發,但如果使用
ALTER EVENT TRIGGER
或ALTER TABLE
陳述式設定,且觸發條件狀態設為「副本」或「一律」,則會在複製期間觸發副本。具有安全定義者的函式將由 Cloud SQL 副本中的
cloudsqlexternalsync
建立。如果由任何使用者執行,系統會以cloudsqlexternalsync
的權限���行,而cloudsqlexternalsync
具有cloudsqlsuperuser
和cloudsqlreplica
角色。建議只允許部分使用者使用安全定義者函式。為此,使用者應撤銷預設的 PUBLIC 權限,然後選擇性地授予執行權限。Cloud SQL 不支援自訂表空間。自訂表空間內的所有資料都會遷移至 Cloud SQL 目的地執行個體中的
pg_default
表空間。遷移至現有目的地執行個體的限制
- 現有的目的地執行個體必須為空白,或僅包含系統設定資料。不支援遷移至含有使用者資料 (例如資料表) 的現有目的地執行個體。
如果現有目的地執行個體中的額外資料導致問題,請清除目的地執行個體中的資料庫,然後重新嘗試遷移工作。請參閱「清除現有目的地執行個體中的額外資料」。
- 每個目的地執行個體只能設定一項遷移工作。
- 您只能遷移至獨立的 Cloud SQL 執行個體。系統不支援遷移至外部伺服器副本。
- 不支援將資料遷移至已啟用 Private Service Connect 的 Cloud SQL 執行個體。
- 升級執行個體後,您必須開啟時間點復原功能。
- 如果執行個體有自訂備份設定 (例如自訂備份位置),升級執行個體後,您必須重新自訂備份設定。在升級程序期間,Cloud SQL 會將備份設定重設為預設值。
- Terraform 使用者:資料庫移轉服務會修改目的地執行個體的備份與復原設定。這可能會導致目的地執行個體設定與您用於佈建的 Terraform 設定不同。如果遇到這個問題,請按照「診斷問題」中的指引操作。
配額
- 無論何時均可存在多達 2,000 個連線設定檔和 1,000 個遷移工作。如要建立更多空間,可以刪除遷移工作 (包含已完成的工作) 和連線設定檔。
- 現有的目的地執行個體必須為空白,或僅包含系統設定資料。不支援遷移至含有使用者資料 (例如資料表) 的現有目的地執行個體。