本頁面說明如何設定網路連線,以便透過資料庫移轉服務,將自行代管的 Oracle 來源異質遷移至 PostgreSQL 適用的 Cloud SQL。
您可以透過三種不同方法,為從自行託管的 Oracle 來源進行遷移作業,設定必要的網路連線:
設定 IP 許可清單連線
如要使用公開 IP 許可清單連線方式,請按照下列步驟操作:
- 請確認來源資料庫的 IP 位址可從公開網際網路連線。您不需要使用 IP 位址連線。 如果 IP 位址有相關聯的 DNS 記錄,也可以使用該記錄。
- 在來源資料庫伺服器上建立連入防火牆規則,接受資料庫移轉服務的連線。請使用下列設定:
- 規則類型請使用
port
。 - 在允許的 IP 位址範圍中,為您建立遷移作業的區域新增所有 資料庫移轉服務公開 IP 位址。
- 將通訊協定設為
TCP
。 - 將與規則相關聯的通訊埠編號,設為來源資料庫接聽連入連線的通訊埠。這個通訊埠號碼與您在來源連線設定檔中輸入的號碼相同。
Oracle 伺服器預設使用
1521
通訊埠。
設定防火牆規則的步驟會因使用的伺服器軟體而異。詳情請參閱防火牆產品的說明文件。
- 規則類型請使用
- 稍後 建立來源連線設定檔時,請在「定義連線方式」部分選取「IP 許可清單」。
透過轉送 SSH 通道設定連線
如要透過安全殼層 (SSH) 通道連線至來源資料庫,請按照下列步驟操作:
- 建立虛擬機器 (VM),開啟資料庫移轉服務與來源資料庫之間的通道。通道伺服器可以是任何 Unix/Linux 主機,只要符合下列條件:
- 可透過 SSH 從公開網際網路存取。
- 可存取來源資料庫的私人 IP 位址。
在 SSH 伺服器上,建立資料庫遷移服務可用來連線至 SSH 通道的使用者帳戶。
舉例來說,在 Ubuntu 系統上,您可以使用下列指令:
- 建立使用者帳戶:
adduser TUNNEL_ACCOUNT_USERNAME
- 限制使用者帳戶的 Shell 存取權,以提升安全性:
usermod -s /usr/sbin/nologin TUNNEL_ACCOUNT_USERNAME
- 建立使用者帳戶:
決定資料庫移轉服務連線至通道時要使用的驗證方法。
您可以使用密碼,或產生
PEM
格式的 SSH 金鑰,之後建立來源連線設定檔時,即可將金鑰上傳至資料庫遷移服務。- 如要使用密碼,則無須進行任何額外設定。請記下您為 TUNNEL_ACCOUNT_USERNAME 帳戶建立的密碼。
- 如要使用金鑰驗證,請產生私密/公開金鑰組。舉例來說,您可以使用
ssh-keygen
公用程式:- 產生金鑰組:
ssh-keygen -m PEM -f YOUR_KEY_NAME
- 將公開金鑰 (
YOUR_KEY_NAME.pub
) 複製到通道伺服器上的~/.ssh/
目錄。 - 儲存私密金鑰。建立來源連線設定檔時,您稍後需要將這個檔案上傳至資料庫遷移服務。
- 產生金鑰組:
- 編輯
/etc/ssh/sshd_config
檔案,設定轉接的安全殼層通道,以符合貴機構的需求。建議您使用下列設定:# Only allow the Database Migration Service user to connect. AllowUsers TUNNEL_ACCOUNT_USERNAME # Send keep-alive packets every 60 seconds to ensure that # the tunnel doesn't close during the migration ServerAliveInterval=60 # Optional: Force key-based authentication PasswordAuthentication no # Enables Database Migration Service to connect from a different host PermitTunnel yes GatewayPorts yes
- 執行
ssh
指令來啟動通道。使用下方的任何指令資料之前,請先替換以下項目:
- TUNNEL_SERVER_SSH_PORT,其中包含伺服器監聽 SSH 連線的通訊埠號碼。
- SOURCE_DATABASE_PRIVATE_IP,並使用來源資料庫的私人 IP 位址。SSH 伺服器必須能夠連線至該 IP。
- SOURCE_DATABASE_PORT,並提供來源資料庫接聽連線的通訊埠編號。Oracle 的 TCP 連線預設通訊埠號碼為
1433
。 - USERNAME,其中包含將執行通道的使用者帳戶名稱。這個帳戶與 TUNNEL_ACCOUNT_USERNAME不同。
- TUNNEL_SERVER_PUBLIC_IP,並使用安全殼層通道伺服器的公開 IP。
ssh -N -L \ TUNNEL_SERVER_SSH_PORT:SOURCE_DATABASE_PRIVATE_IP:SOURCE_DATABASE_PORT \ USERNAME@TUNNEL_SERVER_PUBLIC_IP
- 在 SSH 通道上建立連入防火牆規則,接受來自 資料庫移轉服務公開 IP 位址的連線,這些 IP 位址位於您建立移轉作業的區域。
- 稍後
建立來源連線設定檔時,請按照下列步驟操作:
- 在「定義連線詳細資料」部分,輸入來源 Oracle 執行個體的私人 IP。
- 在「定義連線方式」部分,選取「轉送 SSH 通道」。
- 提供 SSH 伺服器的公開 IP 位址或主機名稱。
- 請提供您在通道伺服器上為 SSH 連線指定的通訊埠。
- 輸入您為資料庫移轉服務建立的使用者名稱,以便連線 (即 TUNNEL_ACCOUNT_USERNAME 的值)。
- 從「驗證方式」下拉式選單中,選取要搭配 TUNNEL_ACCOUNT_USERNAME 使用者的驗證方式:
透過虛擬私有雲對等互連設定私人連線
使用這種連線方法時,來源資料庫的 IP 位址或主機名稱必須可從 Google Cloud 虛擬私有雲存取。如果來源位於外部網路,可能需要使用 Cloud VPN 或 Cloud Interconnect 等額外網路元件。 Google Cloud
適用於 Google Cloud的自行託管來源
如要透過虛擬私有雲對等互連,使用私人連線連線至 Compute Engine VM 上代管的來源 Oracle 資料庫,請按照下列步驟操作:
- 確認已為 VM 指派 IP 位址的虛擬私有雲網路設定私人服務存取權。詳情請參閱「 設定私人服務存取權」。
- 在資料庫移轉服務中, 建立私人連線設定,與您在 Compute Engine VM 上代管 Oracle 資料庫的虛擬私有雲網路建立對等互連。
- 稍後
建立來源連線設定檔時,請按照下列步驟操作:
- 在「定義連線詳細資料」區段中,輸入代管 Oracle 資料庫的 Compute Engine VM 的 IP 位址。
您可以在 Google Cloud 控制台中 查看 VM 的 IP 位址。
- 在「定義連線方式」部分,選取「私人連線 (虛擬私有雲對等互連)」。
- 從下拉式選單中,選取您在上一個步驟中建立的私人連線設定。
- 在「定義連線詳細資料」區段中,輸入代管 Oracle 資料庫的 Compute Engine VM 的 IP 位址。
適用於外部自行託管的來源 Google Cloud
如要透過虛擬私有雲對等互連功能,為位於Google Cloud外部網路的自架 Oracle 來源資料庫使用私人連線,請按照下列步驟操作:
-
使用 Cloud VPN 設定與 Oracle 來源的直接連線。
視網路架構而定,您可能需要在系統中設定其他 VPN 閘道。詳情請參閱 Cloud VPN 說明文件中的「 建立連結至對接 VPN 閘道的高可用性 VPN 閘道」。
- 選用:如果無法在 Cloud VPN 所在的虛擬私有雲網路中建立私人連線設定,請在 Compute Engine 上 建立反向 Proxy 虛擬機器 (VM),轉送虛擬私有雲之間的連線。
- 在資料庫移轉服務中, 建立私人連線設定,與 Cloud VPN 所在的虛擬私有雲網路對等互連。
- 稍後
建立來源連線設定檔時,請按照下列步驟操作:
- 在「定義連線詳細資料」部分,輸入 Oracle 來源的私人 IP。
- 在「定義連線方式」部分,選取「私人連線 (虛擬私有雲對等互連)」。
- 從下拉式選單中,選取您在上一個步驟中建立的私人連線設定。
後續步驟
如要進一步瞭解來源資料庫網路連線,請參閱「 來源網路方法總覽」。
如需完整的逐步遷移導覽,請參閱 Oracle 遷移至 PostgreSQL 適用的 Cloud SQL 遷移指南。