全部產品
Search
文件中心

Data Transmission Service:建立Oracle資料訂閱任務

更新時間:Jan 03, 2025

通過資料訂閱功能,您可以即時訂閱源庫的增量資料,輕鬆協助業務實現輕量級緩衝更新、業務非同步解耦、含ETL邏輯的資料即時同步等情境。本文為您介紹如何建立Oracle資料訂閱任務。

前提條件

  • 自建Oracle資料庫的版本為9i、10g、11g版本,暫不支援為RAC或PDB執行個體。

  • 自建Oracle資料庫已開啟Supplemental Logging,且要求supplemental_log_data_pk,supplemental_log_data_ui已開啟,詳情請參見Supplemental Logging

  • 自建Oracle資料庫已開啟ARCHIVELOG(歸檔模式),設定合理的歸檔日誌保持周期且歸檔日誌能夠被訪問,詳情請參見ARCHIVELOG

  • 若源庫為傳統網路的執行個體,則不支援通過公網IP方式進行資料訂閱。

注意事項

類型

說明

源庫限制

  • 頻寬要求:源庫所屬的伺服器需具備足夠出口頻寬,否則將影響資料訂閱速率。

  • 如果源庫通過專線的方式接入,那麼需要將其中任意1個VIP配置到串連資訊中,實現Oracle RAC通過專線接入訂閱任務。

  • 如自建Oracle為RAC架構,且用專線/VPN網關/Smart Access Gateway、資料庫網關DG、雲企業網CEN和ECS的接入方式,則不支援配置ScanIP,僅支援將其中任意1個VIP配置到串連資訊中,該方式配置後不支援RAC的節點切換。

  • 待訂閱的表需具備主鍵或唯一約束,且欄位具有唯一性,否則可能會導致訂閱到的重複資料。

  • 如訂閱對象為表層級,則單次訂閱任務僅支援至多500張表。當超出數量限制,任務提交後會顯示請求報錯,此時建議您拆分待訂閱的表,配置多個訂閱任務,或者配置整庫的訂閱任務。

  • Redo Log、Archive Log:

    • 需開啟。

    • DTS要求來源資料庫的Redo Log、Archive Log儲存24小時以上,否則DTS可能因無法擷取Redo Log、Archive Log而導致任務失敗,極端情況下甚至可能會導致資料不一致或丟失。由於您所設定的Redo Log、Archive Log儲存時間低於DTS要求的時間進而導致的問題,不在DTS的SLA保障範圍內。

其他限制

  • 請確認DTS對資料類型為FLOAT或DOUBLE的列的訂閱精度是否符合業務預期。DTS會通過ROUND(COLUMN,PRECISION)來讀取這兩類列的值。如果沒有明確定義其精度,DTS對FLOAT的訂閱精度為38位,對DOUBLE的訂閱精度為308位。

  • 若您訂閱的單行資料超過16MB,則不支援消費,否則可能會導致消費用戶端記憶體OOM(Out of Memory)。

  • 若執行個體運行失敗,DTS技術支援人員將在8小時內嘗試恢複該執行個體。在恢複失敗執行個體的過程中,可能會對該執行個體進行重啟、調整參數等操作。

    說明

    在調整參數時,僅會修改執行個體的參數,不會對資料庫中的參數進行修改。

準備工作

登入待訂閱的Oracle資料庫,建立用於資料訂閱的資料庫帳號並授予DBA許可權。授權方式,請參見CREATE USERGRANT USER

重要

如需訂閱增量資料,且不允許授予DBA許可權,您需要按照如下方法開啟歸檔和補充日誌,並為Oracle資料庫帳號授予更精細化的許可權。

  1. 開啟歸檔和補充日誌。

    日誌類型

    開啟步驟

    歸檔日誌

    執行如下命令,開啟歸檔日誌:

    shutdown immediate;
    startup mount;
    alter database archivelog;
    alter database open;
    archive log list;

    補充日誌

    按業務需求,選擇開啟庫層級補充日誌或者表層級補充日誌:

    說明

    開啟庫層級補充日誌,則DTS任務運行更為穩定;開啟表層級補充日誌,則更節約源Oracle資料庫的磁碟空間。

    • 開啟庫層級補充日誌

      1. 開啟最小補充日誌:

        alter database add supplemental log data;
      2. 開啟庫級主鍵、唯一鍵補充日誌:

        alter database add supplemental log data (primary key,unique index) columns;
    • 開啟表級補充日誌

      1. 開啟最小補充日誌:

        alter database add supplemental log data;
      2. 開啟表級補充日誌(兩者選其一) :

        • 開啟表層級主鍵補充日誌

          alter table table_name add supplemental log data (primary key) columns;
        • 開啟表層級全欄位補充日誌

          alter table tb_name add supplemental log data (all) columns ;
  2. 為Oracle資料庫帳號授予更精細化的許可權。

    Oracle 9i~11g版本

    #建立資料庫帳號(以rdsdt_dtsacct為例)並進行授權
    create user rdsdt_dtsacct IDENTIFIED BY rdsdt_dtsacct;
    grant create session to rdsdt_dtsacct;
    grant connect to rdsdt_dtsacct;
    grant resource to rdsdt_dtsacct;
    grant execute on sys.dbms_logmnr to rdsdt_dtsacct;
    grant select on V_$LOGMNR_LOGS to rdsdt_dtsacct;
    grant select on all_objects to rdsdt_dtsacct;
    grant select on all_tab_cols to rdsdt_dtsacct;
    grant select on dba_registry to rdsdt_dtsacct;
    grant select any table to rdsdt_dtsacct;
    grant select any transaction to rdsdt_dtsacct;
    -- v$log privileges
    grant select on v_$log to rdsdt_dtsacct;
    -- v$logfile privileges
    grant select on v_$logfile to rdsdt_dtsacct;
    -- v$archived_log privileges
    grant select on v_$archived_log to rdsdt_dtsacct;
    -- v$parameter privileges
    grant select on v_$parameter to rdsdt_dtsacct;
    -- v$database privileges
    grant select on v_$database to rdsdt_dtsacct;
    -- v$active_instances privileges
    grant select on v_$active_instances to rdsdt_dtsacct;
    -- v$instance privileges
    grant select on v_$instance to rdsdt_dtsacct;
    -- v$logmnr_contents privileges
    grant select on v_$logmnr_contents to rdsdt_dtsacct;
    -- system tables
    grant select on sys.USER$ to rdsdt_dtsacct;
    grant select on SYS.OBJ$ to rdsdt_dtsacct;
    grant select on SYS.COL$ to rdsdt_dtsacct;
    grant select on SYS.IND$ to rdsdt_dtsacct;
    grant select on SYS.ICOL$ to rdsdt_dtsacct;
    grant select on SYS.CDEF$ to rdsdt_dtsacct;
    grant select on SYS.CCOL$ to rdsdt_dtsacct;
    grant select on SYS.TABPART$ to rdsdt_dtsacct;
    grant select on SYS.TABSUBPART$ to rdsdt_dtsacct;
    grant select on SYS.TABCOMPART$ to rdsdt_dtsacct;

操作步驟

  1. 進入訂閱任務的列表頁面。

    1. 登入Data Management服務

    2. 在頂部功能表列中,單擊整合與開發

    3. 在左側導覽列,選擇資料轉送(DTS) > 資料訂閱

    說明
  2. 訂閱任務右側,選擇訂閱執行個體所屬地區。

    說明

    新版DTS訂閱工作清單頁面,需要在頁面左上方工作台的右側,選擇訂閱執行個體所屬地區。

  3. 單擊建立任務,配置源庫資訊以及消費網路類型。

    警告

    選擇源執行個體後,建議您仔細閱讀頁面上方顯示的使用限制,否則可能會導致任務失敗或無法消費訂閱資料。

    類別

    配置

    說明

    任務名稱

    DTS會自動產生一個訂閱名稱,建議配置具有業務意義的名稱(無唯一性要求),便於後續識別。

    源庫資訊

    選擇已有的DMS資料庫執行個體(可選,如未建立可忽略此處選擇,直接在下方設定資料庫資訊即可)

    您可以按實際需求,選擇是否使用已有執行個體。

    • 如使用已有執行個體,資料庫資訊將自動填入,您無需重複輸入。

    • 如不使用已有執行個體,您需要輸入下方的資料庫資訊。

    資料庫類型

    選擇Oracle

    接入方式

    根據源執行個體的類型進行選擇,本文以ECS自建資料庫為例介紹配置流程。

    說明

    當執行個體為自建資料庫時,您還需要執行相應的準備工作,詳情請參見準備工作概覽

    執行個體地區

    選擇自建Oracle資料庫所屬地區。

    ECS執行個體ID

    選擇自建Oracle資料庫所屬ECS執行個體ID。

    連接埠號碼

    填入自建Oracle資料庫的服務連接埠,預設為1521

    Oracle類型

    • 非RAC執行個體:選擇該項後,您還需要填寫SID資訊。

    • RAC或PDB執行個體:選擇該項後,您還需要填寫ServiceName資訊。

      重要

      暫不支援為RAC或PDB執行個體。

    本樣本選擇為非RAC執行個體

    資料庫帳號

    填入自建Oracle的資料庫帳號,許可權要求,請參見準備工作

    資料庫密碼

    填入該資料庫帳號對應的密碼。

    消費網路類型

    網路類型

    資料訂閱執行個體的網路類型固定為專用網路,您需要選擇具體的專用網路虛擬交換器。更多資訊請參見專用網路

    說明
    • 任務建立成功後,消費網路類型不可更改。

    • 若您的資料訂閱用戶端部署在專用網路上,則建議選擇與用戶端一致的專用網路虛擬交換器

    • 通過內網地址進行資料訂閱時,網路延遲最小。

  4. 配置完成後,單擊頁面右下角的測試連接以進行下一步

    如果來源資料庫是阿里雲資料庫執行個體(例如RDS MySQLApsaraDB for MongoDB等),DTS會自動將對應地區DTS服務的IP地址添加到阿里雲資料庫執行個體的白名單;如果來源資料庫是ECS上的自建資料庫,DTS會自動將對應地區DTS服務的IP地址添加到ECS的安全規則中,您還需手動在ECS上的自建資料庫中添加對應地區DTS服務的IP地址,以允許來自DTS伺服器的訪問;如果來源資料庫是IDC自建資料庫或其他雲資料庫,則需要您手動添加對應地區DTS服務的IP地址,以允許來自DTS伺服器的訪問。DTS服務的IP地址,請參見DTS伺服器的IP位址區段

    警告

    DTS自動添加或您手動添加DTS服務的公網IP位址區段可能會存在安全風險,一旦使用本產品代表您已理解和確認其中可能存在的安全風險,並且需要您做好基本的安全防護,包括但不限於加強帳號密碼強度防範、限制各網段開放的連接埠號碼、內部各API使用鑒權方式通訊、定期檢查並限制不需要的網段,或者使用通過內網(專線/VPN網關/智能網關)的方式接入。

  5. 配置任務對象及進階配置。

    配置

    說明

    需要訂閱的資料類型

    需要訂閱的資料類型預設已勾選,且不支援修改。

    • 資料更新

      訂閱已選擇對象的增量資料更新,包含資料的INSERT、DELETE和UPDATE操作。

    • 結構更新

      訂閱整個執行個體所有對象的結構建立、刪除及修改,您需要使用資料訂閱用戶端過濾所需的資料。

    源庫對象

    源庫對象列表中,選擇待訂閱對象,單擊表徵圖向右小箭頭,將其移動到已選擇對象列表中。

    說明

    訂閱對象支援選擇的粒度為庫、表。

    • 如果選擇整個庫作為訂閱對象,那麼該庫中新增對象的增量資料也可以被訂閱到。

    • 如果選擇某個表作為訂閱對象,那麼只有這個表的增量資料可以被訂閱到。此時如果需要加入一個新的表作為訂閱對象,您需要將其加入至訂閱對象中,詳情請參見修改訂閱對象

  6. 單擊下一步高級配置,進行進階配置。

    配置

    說明

    選擇調度該任務的專屬叢集

    DTS預設將任務調度到共用叢集上,您無需選擇。您可以購買指定規格的專屬叢集來運行DTS訂閱任務,詳情請參見什麼是DTS專屬叢集

    源庫、目標庫無法串連後的重試時間

    在訂閱任務串連失敗時,DTS會立即進行持續的重試串連,預設持續重試時間為720分鐘,您也可以在取值範圍(10~1440分鐘)內自訂重試時間,建議設定30分鐘以上。如果DTS在設定的時間內重新串連上源庫,訂閱任務將自動回復。否則,訂閱任務將失敗。

    說明
    • 針對相同源庫的多個DTS執行個體,如DTS執行個體A和DTS執行個體B,設定網路重試時間時A設定30分鐘,B設定60分鐘,則重試時間以低的30分鐘為準。

    • 由於串連重試期間,DTS將收取任務運行費用,建議您根據業務需要自訂重試時間,或者在源庫釋放後儘快釋放DTS執行個體。

    源庫、目標庫出現其他問題後的重試時間

    在訂閱任務啟動後,若源庫出現非串連性的其他問題(如DDL或DML執行異常),則DTS會報錯並會立即進行持續的重試操作,預設持續重試時間為10分鐘,您也可以在取值範圍(1~1440分鐘)內自訂重試時間,建議設定10分鐘以上。如果DTS在設定的重試時間內相關操作執行成功,訂閱任務將自動回復。否則,訂閱任務將會失敗。

    重要

    源庫、目標庫出現其他問題後的重試時間的值需要小於源庫、目標庫無法串連後的重試時間的值。

    環境標籤

    您可以根據實際情況,選擇用於標識執行個體的環境標籤。本樣本無需選擇。

    監控警示

    是否設定警示,當訂閱失敗或延遲超過閾值後,將通知警示連絡人。

  7. 上述配置完成後,單擊頁面右下角的下一步儲存任務並預檢查

    您可以將滑鼠游標移動至下一步儲存任務並預檢查按鈕上,然後單擊氣泡中的預覽OpenAPI調用,查看調用API介面配置該執行個體時的參數資訊。

    說明
    • 在訂閱任務正式啟動之前,會先進行預檢查。只有預檢查通過後,才能成功啟動訂閱任務。

    • 如果預檢查失敗,請單擊失敗檢查項後的查看詳情,並根據提示修複後重新進行預檢查。

    • 如果預檢查產生警告:

      • 對於不可以忽略的檢查項,請單擊失敗檢查項後的查看詳情,並根據提示修複後重新進行預檢查。

      • 對於可以忽略無需修複的檢查項,您可以依次單擊點擊確認警示詳情確認屏蔽確定重新進行預檢查,跳過警示檢查項重新進行預檢查。如果選擇屏蔽警示檢查項,可能會導致資料不一致等問題,給業務帶來風險。

  8. 預檢查通過率顯示為100%時,單擊下一步購買

  9. 購買頁面,選擇資料訂閱執行個體的計費方式,詳細說明請參見下表。

    參數

    說明

    計費方式

    • 預付費(訂用帳戶):在建立執行個體時支付費用。適合長期需求,價格比隨用隨付更實惠,且購買時間長度越長,折扣越多。

    • 後付費(隨用隨付):按小時計費。適合短期需求,用完可立即釋放執行個體,節省費用。

    資源群組配置

    執行個體所屬的資源群組,預設為default resource group。更多資訊,請參見什麼是資源管理

    訂閱時間長度

    在預付費模式下,選擇訂用帳戶執行個體的時間長度和數量,包月可選擇1~9個月,包年可選擇1年、2年、3年和5年。

    說明

    該選項僅在付費類型為預付費時出現。

  10. 配置完成後,閱讀並勾選《資料轉送(隨用隨付)服務條款》

  11. 單擊購買並啟動,訂閱任務正式開始,您可在工作清單查看具體任務進度。

後續步驟

成功運行訂閱任務後,您需要新增消費組,並根據下遊用戶端選擇訂閱資料的消費方式。

  1. 消費組的建立和管理,請參見新增消費組

  2. 根據消費用戶端的類型,選擇訂閱資料的消費方式: