為滿足跨時區業務協同和統一資料處理的需求,企業常需將分布在不同地區的DataWorks工作空間調度基準統一到特定時區(如UTC+0或UTC+8)。DataWorks支援將DataWorks調度時區從地區預設時區修改為指定時區。本文介紹具體操作,並詳述其對調度任務和相關配置的影響。您需在充分預估風險的前提下完成時區切換,確保全球業務的定時調度邏輯統一,規避因時區不一致導致的調度混亂和資料錯誤。
支援修改調度時區的地區
預設情況下,DataWorks工作空間所在地區對應的時區即為調度時區(即任務定時調度時間所使用的時區)。DataWorks部分地區支援修改調度時區,可切換時區的地區與地區支援切換的時區如下:
支援切換時區的地區 | 切換至UTC+0時區 | 切換至UTC+8時區 |
美國(矽谷) | 支援 | 支援 |
美國(維吉尼亞) | 支援 | 支援 |
德國(法蘭克福) | 支援 | 支援 |
新加坡 | 支援 | 支援(同本地時區) |
中國香港 | 支援 | 支援(同本地時區) |
日本(東京) | 支援 | 支援 |
例如:美國(矽谷)地區的DataWorks工作空間,支援將調度時區從本地預設時區切換為UTC+0時區或UTC+8時區。當時區修改成功後,可在營運中心頂部提示欄或資料開發節點的處確認時區切換是否成功。
(必讀)時區切換注意事項
為避免時區切換導致線上業務出錯或不符合預期,執行時區切換前請務必仔細閱讀以下內容。
分類 | 說明 |
修改後影響的工作空間範圍 | 調度時區是地區層級,修改的調度時區在本地區所有工作空間中生效。 |
修改操作無法復原 | 調度時區修改後不可更改,請您謹慎操作。 重要 該操作涉及到存量資料的遷移(已經存在的節點和執行個體),可能會對業務造成影響,請綜合評估後謹慎選擇。 |
修改後影響的配置範圍 | 調度時區切換後將影響DataWorks調度相關配置與代碼參數替換(調度參數會根據任務定時時間、業務時間計算的調度參數實際值,作為調度情境下代碼的實際入參)等。
重要
|
(重點)時區切換對產品的側影響
調度時區切換後將會影響DataWorks調度相關配置、調度情境下參數替換以及部分模組介面時間展示等,影響詳情如下。
切換調度時區僅對調度情境生效,由於DataStudio大部分操作非調度環境,所以在DataStudio執行任務時,預設仍按照當地時區替換時間參數,例如DataStudio中單節點運行、帶參運行、臨時查詢等操作不受調度時區變更影響。
由於DataStudio中商務程序運行、開發環境煙霧測試 (Smoke Test)操作會進入調度系統,所以節點代碼中時間參數將受調度時區變更影響。
影響一:節點定時時間
節點定時調度時間會按照設定的調度時區變化。
影響二:節點時間參數配置
節點調度參數會按照任務相關時間(任務定時時間,業務日期等)為基準值替換代碼中的變數,該值會根據的調度時區的改變而改變。
YYYYMMDD=${yyyymmdd} LAST_2D=${yyyymmdd-2}
影響三:節點代碼中時間相關的處理邏輯
代碼裡面設定的變數,一部分會在gateway解析,另一部分會在計算引擎側解析,具體解析邏輯如下:
如果是在gateway上解析的,會按照設定的調度時區變化。調度情境下(不包括資料開發臨時運行),若您在DataWorks指令碼任務(例如Shell,pyodps)中,直接執行擷取時間命令(例如Shell節點中執行date命令),系統會根據您調度時區返回時間。
如果是在底層計算引擎側解析的,請參考底層計算引擎側的時區轉換規則進行瞭解,具體請參見對應引擎說明文檔。
以下圖為例,調度情境下,代碼中的時間變數將根據調度時間替換為具體的時間字串下發至Hive,具體表達的時間,受限於Hive服務端解析邏輯。
影響四:基準或警示相關的時間
基準或警示相關的時間會按照設定的調度時區變化。
影響五:API相關的時間
API相關的時間會按照設定的調度時區變化。
影響六:底層引擎的時區
底層引擎(例如,Data Integration、MaxCompute等)的時區是由各自引擎自己設定的,與DataWorks調度時區不轉換。調度參數實際替換值將按照純字串形式下發至引擎側按自身規則自行處理,關於引擎處理方案請參考引擎時區的相關說明文檔。
調度時區切換僅對任務調度時間相關屬性生效,不涉及引擎時區變更。
關於Data Integration該情境處理說明,詳情請參見附錄:Data Integration相關時間處理。
如何切換時區
DataWorks調度支援從本地時區切換到其他非本地時區。
情境一:該租戶第一次建立專案
在支援切換時區的地區下建立工作空間時,若為全新使用者首次建立,會彈窗提示可修改調度時區為非本地時區,具體修改操作需要提交工單聯絡技術支援人員修改,您可根據業務需要以及(必讀)時區切換注意事項評估確認是否需要修改。
情境二:該租戶非第一次建立專案
在支援切換時區的地區下建立工作空間時,若需要將已有工作空間調度時區修改為非本地時區,您同樣需要提交工單聯絡技術支援人員修改,但由於涉及到存量資料的遷移(已經存在的節點和執行個體),可能對業務造成影響,請綜合評估。切換大致分為以下幾步:
使用者側:存量資料的影響面評估。
平台側:存量資料的遷移。
平台側:設定新時區。
使用者側:存量資料的恢複/新時區的驗證。
建議您對各類型任務進行多次驗證以確認任務運行無誤。
確認時區切換是否成功
時區切換成功後,您可前往資料開發頁面的節點編輯頁(非新版工作流程中的節點)調度配置中以及營運中心頁面確認時區設定是否生效。
方法一:調度配置頁面查看

進入資料開發頁面。
登入DataWorks控制台,切換至目標地區後,單擊左側導覽列的,在下拉框中選擇對應工作空間後單擊進入資料開發。
單擊開啟已有資料開發節點或建立節點,進入節點編輯頁面。
在節點編輯頁面,單擊進入頁簽,查看設定的時區是否生效。
方法二:營運中心頁面查看
登入DataWorks控制台,切換至目標地區後,單擊左側導覽列的,在下拉框中選擇對應工作空間後單擊進入營運中心,在營運中心頂部的提示欄會提示當前配置時區。

附錄:Data Integration相關時間處理
Data Integration時區與DataWorks調度時區不轉換,調度參數實際替換值將按照純字串形式下發至Data Integration側。這裡以where條件資料過濾為例gmt_modify >= ${yyyymmdd},這個資料過濾SQL會按照字串字面值發送給資料來源執行,實際執行過濾效果受限於資料來源本身時區處理機制。
Data Integration同步進程時區屬於DataWorks工作空間當地Region時區,同步進程時間不隨DataWorks調度時區進行切換,部分資料來源同步時會和同步進程時區有關,也請您留意此處約束。