本頁說明如何為 Cloud Data Fusion 執行個體定義維護期間。
維護時間窗格適用於 Cloud Data Fusion 6.8.0 以上版本的執行個體。
關於維護期間
Cloud Data Fusion 中的維護時間是指您允許系統執行維護作業的時間範圍,可降低在使用率高峰期間服務中斷的風險。請在非尖峰時段或活動較少的時間安排維護期間,以盡量減少對 Cloud Data Fusion 執行個體和管道執行作業的影響。
您可以設定維護期間,控管執行個體何時執行維護作業:
- 如果已定義維護期間,Cloud Data Fusion 會在指定期間內執行維護作業。
- 如果未定義維護期間,系統可隨時執行維護作業。
關於維護作業
為確保系統安全和法規遵循,Cloud Data Fusion 會定期執行維護作業。這些作業包括套用重要更新和安全性修補程式,以減輕漏洞風險並保護使用者資料。排定維護期間可確保更新能有效率地套用,維持系統完整性,並盡量減少執行個體和管道執行作業的中斷時間。
- 設定維護期間時,您必須每週至少分配 12 小時來進行維護作業。每個時間範圍必須介於 4 到 12 小時之間。
在維護期間,某些作業可能會受到影響。建議您在非用量高峰時段設定維護期間。維護作業可能會對 Cloud Data Fusion 造成以下影響:
- Cloud Data Fusion Studio 介面可能暫時無法使用。
- 管道執行可能會受到影響,導致失敗。
- Cloud Data Fusion 服務可能會暫時停機,導致 API 呼叫失敗。
- 在維護時段內,執行個體可能最多會在 1 小時內無法完全運作。建議您在管道未執行或未排定執行時,設定維護時段。
在建立執行個體時指定維護期間
主控台
如要在建立執行個體時設定維護時段,請按照下列步驟操作:
- 前往 Cloud Data Fusion 的「Instances」(執行個體) 頁面,然後按一下「Create instance」(建立執行個體)。
- 輸入「Instance name」(執行個體名稱)和「Edition」(版本)。如要進一步瞭解各個欄位,請參閱「建立執行個體」。
- 展開「Advanced options」(進階選項) 區段。
- 展開「維護作業」專區,然後按照下列步驟操作:
- 勾選「啟用維護期間」核取方塊。
- 在「開始時間」欄位中,輸入支援格式的時間。
- 在「時區」TimeZone清單中選取時區。
- 在「Days」和「Length」清單中,選取星期幾和時間長度。如要進一步瞭解這些設定,請參閱「關於維護作業」。
- 按一下 [建立]。
詳情請參閱「設定維護期間時間和重複規則 (RRULE)」。
REST API
- 使用
instance.create
API 設定Instance
:
{
"name": string,
"description": string,
…
…
"maintenancePolicy": {
"maintenanceWindow": {
"recurringTimeWindow": {
"window": {
"startTime": "START_TIME",
"endTime": "END_TIME"
},
"recurrence": "MAINTENANCE_RECURRENCE"
}
},
}
}
更改下列內容:
START_TIME
:時間區間開始時間,採用 RFC 3339 格式。END_TIME
:時間視窗結束時間,採用 RFC 3339 格式。MAINTENANCE_RECURRENCE
:維護期間重複的 RRULE。Cloud Data Fusion 僅支援下列格式:FREQ=WEEKLY;BYDAY=SU,MO,TU,WE,TH,FR,SA
或BYDAY=SU,MO,TU,WE,TH,FR,SA,MO;FREQ=WEEKLY
。這會指定在所選日期的週週重複執行視窗,從startTime
開始,並持續指定的時間長度。
詳情請參閱「設定維護期間時間和重複規則 (RRULE)」。
以下範例會建立執行個體,其維護期間為每週星期六和星期日上午 10 點至下午 4 點 (世界標準時間),詳情請參閱 instances API 說明文件。
// POST https://datafusion.googleapis.com/v1/projects/example-project/locations/us-central1/instances?instanceID=example-instance
{
"maintenancePolicy": {
"maintenanceWindow": {
"recurringTimeWindow": {
"window": {
"startTime": "2024-01-01T10:00:00Z",
"endTime": "2024-01-01T16:00:00Z",
},
"recurrence": "FREQ=WEEKLY;BYDAY=SA,SU"
}
},
}
}
gcloud
您可以在使用 gcloud beta data-fusion instances create
指令建立執行個體時,指定維護期間。
下列參數必須為維護期間定義:
--maintenance-window-start
會設定排除期間的開始時間。--maintenance-window-end
會設定視窗的結束時間。--maintenance-window-recurrence
會為維護期間的重複設定 RRULE。
gcloud beta data-fusion instances create INSTANCE_NAME \
--project=PROJECT_NAME \
--location=LOCATION \
--maintenance-window-start=START_TIME \
--maintenance-window-end=END_TIME \
--maintenance-window-recurrence=MAINTENANCE_RECURRENCE
更改下列內容:
INSTANCE_NAME
:執行個體的名稱。PROJECT_NAME
:專案名稱。LOCATION
:執行個體所在的區域名稱。START_TIME
:使用日期/時間輸入格式表示的視窗開始時間。系統只會使用當天指定的時間,而忽略指定的日期。END_TIME
:窗格結束時間,格式為 日期/時間輸入格式。系統只會使用當天指定的時間,而忽略指定的日期。指定的日期和時間必須晚於開始時間。MAINTENANCE_RECURRENCE
:維護期間重複的 RRULE。Cloud Data Fusion 僅支援下列格式:FREQ=WEEKLY;BYDAY=SU,MO,TU,WE,TH,FR,SA
或BYDAY=SU,MO,TU,WE,TH,FR,SA,MO;FREQ=WEEKLY
。這會指定在所選日期的週期性回溯期,從--maintenance-window-start
時間開始,並持續指定的時間長度。
詳情請參閱「設定維護期間時間和重複規則 (RRULE)」。
下列指令會建立執行個體,其維護期間為每週星期六和星期日的下午 12 點至下午 6 點 (世界標準時間),為期六小時。
gcloud beta data-fusion instances create example-instance \
--project='example-project' \
--location='us-east1' \
--maintenance-window-start='2024-01-01T12:00:00Z' \
--maintenance-window-end='2024-01-01T18:00:00Z' \
--maintenance-window-recurrence='FREQ=WEEKLY;BYDAY=SA,SU'
更新執行個體的維護期間
主控台
如要在Google Cloud 主控台中更新現有例項的維護時間,請按照下列步驟操作:
前往 Cloud Data Fusion 的「Instances」(執行個體) 頁面。
按一下執行個體名稱,查看執行個體詳細資料。
在「Instance details」頁面中,前往「Maintenance window」欄位,然後按一下「Edit」。
維護時段欄位會在編輯模式中開啟。視需要更新值:
- 勾選「啟用維護期間」核取方塊。
- 在「開始時間」欄位中,輸入支援格式的時間。
- 在「時區」TimeZone清單中選取時區。
- 在「Days」和「Length」清單中,選取星期幾和時間長度。如要進一步瞭解這些設定,請參閱「關於維護作業」。
按一下 [儲存]。
詳情請參閱「設定維護期間時間和重複規則 (RRULE)」。
REST API
如為現有執行個體,請使用 instances.patch
API 要求更新維護時間窗。這會覆寫現有的維護期間設定 (如有)。否則,系統會如要求主體所述,設定新的設定。
請按照以下方式建構 API 要求:
- 在
updateMask
參數中指定maintenance_policy
遮罩。 - 在要求主體中,在維護政策設定中指定維護期間:
{
"maintenancePolicy": {
"maintenanceWindow": {
"recurringTimeWindow": {
"window": {
"startTime": "START_TIME",
"endTime": "END_TIME"
},
"recurrence": "MAINTENANCE_RECURRENCE"
}
},
}
}
詳情請參閱「設定維護期間時間和重複規則 (RRULE)」。
以下範例會更新執行個體的維護政策設定,每週在週五、週六和週日上午 11 點至下午 3 點 (世界標準時間) 之間提供四小時的維護時段。
// PATCH https://datafusion.googleapis.com/v1/projects/example-project/locations/us-central1/instances/example-instance?updateMask=maintenance_policy
{
"maintenancePolicy": {
"maintenanceWindow": {
"recurringTimeWindow": {
"window": {
"startTime": "2024-01-01T11:00:00Z",
"endTime": "2024-01-01T15:00:00Z",
},
"recurrence": "FREQ=WEEKLY;BYDAY=FR,SA,SU"
}
},
}
}
gcloud
您可以使用 gcloud beta data-fusion instances update
指令更新執行個體的維護期間。
下列參數必須為維護期間定義:
--maintenance-window-start
會設定排除期間的開始時間。--maintenance-window-end
會設定視窗的結束時間。--maintenance-window-recurrence
會為維護期間的重複設定 RRULE。
gcloud beta data-fusion instances update INSTANCE_NAME \
--project=PROJECT_NAME \
--location=LOCATION \
--maintenance-window-start=START_TIME \
--maintenance-window-end=END_TIME \
--maintenance-window-recurrence=MAINTENANCE_RECURRENCE
更改下列內容:
INSTANCE_NAME
:執行個體的名稱。PROJECT_NAME
:專案名稱。LOCATION
:執行個體所在的區域名稱。START_TIME
:使用日期/時間輸入格式表示的視窗開始時間。系統只會使用當天指定的時間,而忽略指定的日期。END_TIME
:窗格結束時間,格式為 日期/時間輸入格式。系統只會使用當天指定的時間,而忽略指定的日期。指定的日期和時間必須晚於開始時間。MAINTENANCE_RECURRENCE
:維護期間重複的 RRULE。Cloud Data Fusion 僅支援下列格式:FREQ=WEEKLY;BYDAY=SU,MO,TU,WE,TH,FR,SA
或BYDAY=SU,MO,TU,WE,TH,FR,SA,MO;FREQ=WEEKLY
。這會指定在所選日期的週期性回溯期,從--maintenance-window-start
時間開始,並持續指定的時間長度。
下列指令會更新執行個體 example-instance
,維護時段為每週六和週日中午 12 點至下午 6 點 (世界標準時間) 的六小時。
gcloud beta data-fusion instances update example-instance \
--project='example-project' \
--location='us-east1' \
--maintenance-window-start='2024-01-01T12:00:00Z' \
--maintenance-window-end='2024-01-01T18:00:00Z' \
--maintenance-window-recurrence='FREQ=WEEKLY;BYDAY=SA,SU'
設定維護期間時間和重複規則 (RRULE)
設定維護期間的開始和結束時間時,系統會忽略提供的時間戳記日期元件。系統只會考量一天中的時間,以及開始時間和結束時間之間的時間長度。時間會以世界標準時間儲存,但您可以使用世界標準時間或時區偏移值,在使用 REST API 或 gcloud CLI 排定維護時段時。
設定週期時,請注意 RRULE 會依照世界標準時間,因此如果您的時區不同,請據此調整。舉例來說,如果您的時區為 PDT (UTC-7),且希望維護期間自當地時間星期三 21:00 開始 (對應於星期四 4:00),請在 RRULE 的 BYDAY
選項中指定 TH
,而非 WE
。
移除執行個體的維護期間
主控台
如要在Google Cloud 控制台中移除現有執行個體的維護期間,請按照下列步驟操作:
前往 Cloud Data Fusion 的「Instances」(執行個體) 頁面。
按一下執行個體名稱,查看執行個體詳細資料。
在「Instance details」頁面中,前往「Maintenance window」欄位,然後按一下「Edit」。
如要從執行個體移除維護期間,請取消勾選「啟用維護期間」核取方塊。
按一下 [儲存]。
REST API
如要從執行個體移除維護期間,請在要求主體中傳遞空白的維護政策物件。
// PATCH https://datafusion.googleapis.com/v1/projects/example-project/locations/us-central1/instances/example-instance?updateMask=maintenance_policy
{
"maintenancePolicy": {}
}
gcloud
如要從執行個體移除維護期間,請使用帶有 --clear-maintenance-window
標記的 gcloud beta data-fusion instances update
指令。
gcloud beta data-fusion instances update INSTANCE_NAME \
--project=PROJECT_NAME \
--location=LOCATION \
--clear-maintenance-window
更改下列內容:
INSTANCE_NAME
:執行個體的名稱。PROJECT_NAME
:專案名稱。LOCATION
:執行個體所在的區域名稱。
後續步驟
- 請參閱 instances API 說明文件。