DSC:數倉SQL腳本遷移的神奇工具

来源:https://www.cnblogs.com/huaweiyun/archive/2023/03/14/17215288.html
-Advertisement-
Play Games

摘要:本文介紹的DSC工具是針對資料庫切換時面臨的遷移任務而開發的免安裝命令行工具。目的是提供簡單、快速、可靠的SQL腳本遷移服務。 本文分享自華為雲社區《GaussDB(DWS)DSC工具系列:DSC工具初識【玩轉PB級數倉GaussDB(DWS)】》,作者:積少成多 。 DSC背景介紹與DSC介 ...


摘要:本文介紹的DSC工具是針對資料庫切換時面臨的遷移任務而開發的免安裝命令行工具。目的是提供簡單、快速、可靠的SQL腳本遷移服務。

本文分享自華為雲社區《GaussDB(DWS)DSC工具系列:DSC工具初識【玩轉PB級數倉GaussDB(DWS)】》,作者:積少成多 。

DSC背景介紹與DSC介紹

當客戶從其它資料庫切換到DWS資料庫時可能會面臨遷移任務,其中包括SQL腳本的遷移。SQL腳本的遷移是一個複雜、高風險、耗時的過程。DSC針對這種情況,應運而生。DSC(Database Schema Convertor)是一款可執行在Linux或Windows操作系統上的命令行工具。其目的便是提供簡單、快速、可靠的SQL腳本遷移服務,通過內置語法遷移邏輯將源資料庫SQL腳本轉換為適用於DWS資料庫的SQL腳本。

DSC的獲取與安裝

DSC的獲取可參考華為雲文檔:客戶端工具下載(https://support.huaweicloud.com/tg-dws/dws_07_0002.html)。官網提供DSC舊版本,新版DSC工具可通過support進行下載。(https://support.huawei.com/enterprise/zh/cloud-computing/hcs-dws-service-pid-251527524/software/258068937/?idAbsPath=fixnode01|22658044|7919788|9856606|251527524)

DSC是一款免安裝工具,下載壓縮包後解壓縮即可使用。關於DSC還有一些相關的硬體、軟體需求,詳情可以參考DSC的官方文檔進行瞭解。(https://support.huaweicloud.com/tg-dws/mt_tool_index.html)

DSC結構

DSC包含7個文件夾,一個runDSC.bat批處理可執行文件和一個runDSC.sh腳本文件。runDSC用於調用執行DSC程式。

DSC目錄結構文件如下:

界面即為命令行界面,切換路徑至runDSC.bat/runDSC.sh的同級目錄即可。其中bin文件夾下存儲DSC轉換邏輯的jar包,最終實現腳本轉換就是通過調用jar包實現。config文件夾下包含一些基礎配置,包含用戶可自定義配置遷移的文件。模塊包括MySQL、TD、Oracle,涉及自定義遷移內容根據模塊不同內容也不盡相同。MySQL模塊中,自定義配置內容包括預設資料庫名稱、索引名重命名、數據映射規則、函數轉換等內容。TD、Oracle中針對遷移過程中的不相容語法也有相應配置參數。lib文件夾下包含DSC使用的外部依賴。log文件夾下留存DSC轉換過程中的日誌記錄,包括dsc遷移日誌和遷移失敗日誌。日誌不會自動清空,每次執行DSC會對日誌進行追加寫。下次執行DSC命令時,需要手動刪除文件夾內內容進行日誌清空。input文件夾下存放要進行遷移的SQL腳本,output文件夾下為DSC進行轉換後的SQL腳本結果。scripts文件夾下包含一些自定義資料庫腳本,用戶可以使用自定義資料庫的SQL腳本從Teradata/Oracle遷移那些不直接存在於目標資料庫的關鍵字。如果需要用到,遷移之前,這些腳本必須在每個目標資料庫中執行一次。

DSC使用

用戶可在Windows和Linux操作系統中執行runDSC.sh或runDSC.bat命令進行遷移,命令格式如下:

./runDSC.sh 相關命令行參數(Linux操作系統) / runDSC.bat 相關命令行參數(Windows操作系統)

相關命令行參數包括以下8個:

DSC執行流程如下:

先根據源庫內容進行自定義功能配置,包括是否需要執行scripts目錄中包含一些自定義資料庫腳本,配置config中的自定義參數。然後命令行執行啟動命令,進行腳本SQL轉換,最後從輸出目錄獲取結果。如果遷移過程遇到問題,可以查看日誌。

結果展示界面(以MySQL為例):

MySQL遷移中,界面會顯示遷移路徑下總文件數,有效文件數,遷移成功文件數和遷移失敗文件數以及日誌存放路徑。不同模塊下顯示界面略有差異。

轉換結果展示(左為源文件內SQL,右為經DSC轉換後的結果):

常見問題彙總、歸納以及解決辦法

常見故障處理可見DSC官方手冊《DSC故障處理》一節。

在使用過程中常見的問題有以下幾個可供參考:

1、在安裝過程中,提示“ Root privileged users are not allowed to install the DSC for Linux. ”

解決辦法:擁有root許可權的用戶不得在Linux中安裝和執行DSC。建議使用沒有root許可權的用戶來安裝和操作DSC。

2、轉換結果中中文有亂碼

解決辦法:修改config中對應模塊下的編碼方式。以MySQL為例,修改config/features-mysql.properties中的table.database.encoding參數。以及建議將input路徑下的文件改為UTF8編碼方式規避中文亂碼。

3、SQL存在轉換失敗的問題:DSC手冊中記錄可轉換的內容轉換失敗或轉換錯誤。

解決辦法:先嘗試通過support獲取最新DSC工具,嘗試問題是否解決,如果問題未解決可聯繫相關維護人員支撐。

 

點擊關註,第一時間瞭解華為雲新鮮技術~


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • DNS功能變數名稱系統服務 1.DNS 介紹 1.1什麼是功能變數名稱? 功能變數名稱(Domain Name),簡稱功能變數名稱、網域,是由一串用點分隔的名字組成的Internet上某一臺電腦或電腦組的名稱,用於在數據傳輸時標識電腦的電子方位。具有獨一無二,不可重覆的特性。 1.2什麼是 DNS? 功能變數名稱系統(Domain ...
  • iptables是一個Linux內核中的包過濾工具,可以用來過濾、轉發、修改、控制網路流量等。如果想要將主機的所有流量轉發至其他機器,可以使用iptables進行配置。 以下是具體步驟: 1. 首先需要在其他機器上開啟轉發功能,可以使用以下命令開啟: echo 1 > /proc/sys/net/i ...
  • 初識 chrony chrony 是網路時間協議(Network Time Protocol )的通用實現 它不但可以提供保持系統時間與 NTP 時鐘伺服器同步的服務,還能作為 NTP 伺服器對其他伺服器提供時間同步服務 chrony 特點: 任何情況下都能穩定良好運行(例如不穩定的網路中、不穩定的 ...
  • 項目中有個需求是要對文本內容檢索並重寫,我們使用的是 WriteFile 覆蓋舊的文本內容 最小示例: #include <Windows.h> #include <iostream> int main() { HANDLE hFile = CreateFile(L"File.txt", // Op ...
  • Linux操作系統是一種多任務、多用戶的操作系統,這意味著它可以同時運行多個進程,每個進程都可以執行不同的任務。 在本文中,我們將介紹如何在Linux系統中創建和銷毀進程。 進程的創建 在Linux系統中,進程的創建可以通過fork()系統調用來實現。 fork()函數將當前進程複製一份,創建一個新 ...
  • Linux文件許可權管理介紹 一:Ubuntu 簡介 1 、什麼是Ubuntu Ubuntu是基於Debian開發的一個開源的Linux操作系統,Ubuntu這個名字名稱來⾃⾮洲南部某種語言的一個詞語,Ubuntu每6個月會發佈⼀個新版本,每隔兩年,在四月份的時候,會推出⼀個⻓期⽀持版本(LTS)。其 ...
  • 第一步就是安裝 為了節省資源,運行起來更快捷,首先是在電腦上安裝好vm虛擬機, 新建虛擬機,安裝xp,也就是把xp光碟文件導入, 接著在虛擬機中下載oracle,解壓的話會用到WinRAR,也一併導入虛擬機C盤 然後在主機上,安裝客戶端client,plsql, 打開虛擬機中的監聽,連接資料庫, 登 ...
  • 摘要:本文主要為大家帶來Mysql中的3種數據類型和3種運算符。 本文分享自華為雲社區《Mysql中的數據類型和運算符》,作者: 1+1=王。 Mysql的數據類型 Mysql支持數值型、文本型和日期時間型三大數據類型。 數值型數據 數值型是描述定量數據的數據類型,包括整數型數據類型和浮點型數據類型 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...