使用 gcloud CLI 寫入及查詢記錄項目
本文介紹一些 Cloud Logging 的功能,並說明如何執行下列操作:
- 使用 Google Cloud CLI 寫入記錄項目。
- 使用 gcloud CLI 列出記錄項目。
- 使用 Logging API 列出記錄項目。
- 使用記錄檔探索工具查看及查詢記錄項目。
事前準備
您必須擁有啟用計費功能的 Cloud de Confiance 專案,才能完成此快速入門導覽課程。如果您沒有 Cloud de Confiance 專案,或是專案尚未啟用計費功能,請執行下列步驟: Cloud de Confiance-
安裝 Google Cloud CLI。
-
設定 gcloud CLI,使用您的聯合身分。
詳情請參閱「使用聯合身分登入 gcloud CLI」。
-
執行下列指令,初始化 gcloud CLI:
gcloud init -
選取或建立專案所需的角色
- 選取專案:選取專案時,不需要具備特定 IAM 角色,只要您已獲授角色,即可選取任何專案。
-
建立專案:如要建立專案,您需要具備專案建立者角色 (
roles/resourcemanager.projectCreator),其中包含resourcemanager.projects.create權限。瞭解如何授予角色。
-
建立 Cloud de Confiance 專案:
gcloud projects create PROJECT_ID
將
PROJECT_ID替換為您要建立的 Cloud de Confiance 專案名稱。 -
選取您建立的 Cloud de Confiance 專案:
gcloud config set project PROJECT_ID
將
PROJECT_ID替換為 Cloud de Confiance 專案名稱。
-
如要使用現有專案進行本指南中的操作,請確認您具有完成本指南所需的權限。如果您建立新專案,則已具備必要權限。
必要的角色
如要取得建立、列出及刪除記錄檔項目所需的權限,請要求管理員授予您專案的「Logging 管理員 」(roles/logging.admin) IAM 角色。如要進一步瞭解如何授予角色,請參閱「管理專案、資料夾和組織的存取權」。
「記錄檔寫入者」(roles/logging.logWriter) 和「記錄檔檢視者」(roles/logging.viewer) 角色包含建立及列出記錄項目的權限。如要刪除記錄項目,請授予記錄管理員 (roles/logging.admin) 角色,該角色具備建立、列出及刪除記錄項目的權限。請注意,Logging 管理員 (roles/logging.admin) 角色也會授予在 Logging 中執行所有動作的權限。
使用 gcloud CLI 寫入記錄項目
Logging 可支援包含結構化和非結構化資料的記錄項目。結構化資料包含 JSON 資料結構;例如 {"weather": "partly cloudy"}。非結構化資料是字元字串;例如 "A simple entry"。
在後續步驟中,您會使用 gcloud CLI 寫入含有非結構化資料的記錄項目,以及含有結構化資料的記錄項目。gcloud CLI 提供 Cloud Logging API 的指令列介面。
將含有非結構化資料的記錄項目寫入
my-test-log記錄,請執行gcloud logging write指令:gcloud logging write my-test-log "A simple entry."指令完成後,您會看到以下訊息:
Created log entry。將含有結構化資料的記錄項目寫入
my-test-log記錄:gcloud logging write --payload-type=json my-test-log '{ "message": "My second entry", "weather": "partly cloudy"}'使用結構化資料撰寫記錄項目時,必須加入
--payload-type=json。如果您省略這個欄位,Logging 會將酬載解讀為非結構化資料。
如果記錄 my-test-log 不存在,則 Logging 會在收到記錄項目時建立記錄。
使用 gcloud CLI 列出記錄項目
您可以使用 gcloud CLI 從 Logging 擷取記錄項目,並顯示這些項目。舉例來說,如要擷取並顯示資源類型為 global 的記錄項目,請執行下列指令:
gcloud logging read "resource.type=global"
指令會傳回類似以下的結果:
---
insertId: jpj9zjf73t1mn
jsonPayload:
message: My second entry
weather: partly cloudy
logName: projects/myloggingproject/logs/my-test-log
receiveTimestamp: '2018-11-01T18:39:31.114507977Z'
resource:
labels:
project_id: myloggingproject
type: global
timestamp: '2018-11-01T18:39:31.114507977Z'
---
insertId: vd4m1if7h7u1a
logName: projects/myloggingproject/logs/my-test-log
receiveTimestamp: '2018-11-01T18:39:19.718100792Z'
resource:
labels:
project_id: myloggingproject
type: global
textPayload: A simple entry
timestamp: '2018-11-01T18:39:19.718100792Z'
如要瞭解如何讀取記錄,請參閱gcloud logging read參考文件。
在 Logs Explorer 中查看記錄項目
如要在 Cloud de Confiance 控制台中查看記錄項目,可以使用 Logs Explorer。大多數專案都會儲存大量記錄,您可以撰寫查詢來選取特定記錄項目。 Cloud de Confiance
如要使用 Logs Explorer 查看您寫入的記錄項目,請按照下列步驟操作:
-
前往 Cloud de Confiance 控制台的 「Logs Explorer」頁面:
如果您是使用搜尋列尋找這個頁面,請選取子標題為「Logging」的結果。
確認已在導覽列中選取專案 Cloud de Confiance Cloud de Confiance by S3NS。如有必要,請使用 Cloud de Confiance 專案下拉式清單選取 Cloud de Confiance 專案。
在「Resource」(資源) 選單中,選取「Global」(全域)。
如果沒看到「Global」(通用) 選單選項,或找不到記錄項目,請稍候幾分鐘,然後重新整理頁面。Logging 可能需要幾分鐘的時間才能接收記錄項目。
如要查看記錄項目的詳細資料,請按一下該項目的chevron_right「選單」。
第一筆記錄項目的資料儲存在
textPayload。第二個記錄項目包含儲存在jsonPayload中的結構化資料。結構化酬載包含message和weather索引鍵。
如要瞭解記錄項目的資料格式,請參閱 LogEntry 類型。
在 Logs Explorer 中查詢記錄項目
您可以使用查詢編輯器查詢記錄項目,並依索引與項目值篩選具有結構化記錄的記錄項目。舉例來說,如要顯示所有含有文字 simple 的記錄項目,請執行下列操作:
-
前往 Cloud de Confiance 控制台的 「Logs Explorer」頁面:
如果您是使用搜尋列尋找這個頁面,請選取子標題為「Logging」的結果。
在「Resource」(資源) 選單中,選取「Global」(全域)。
在查詢編輯器中,輸入以引號括住的字串
simple。 記錄顯示畫面只會顯示A simple entry.記錄項目。查看記錄之後,請移除您新增的查詢字串,然後按一下「Run query」(執行查詢)。兩個記錄項目都會重新顯示在顯示畫面中。
如要顯示具有結構化資料的所有記錄項目,且結構化資料中已有 weather 索引,同時索引的 value 欄位包含 partly,請執行下列步驟:
查詢編輯器包含
resource.type="global"這一行。 輸入下列指令:jsonPayload.weather:partly按一下「Run query」(執行查詢)。結果會產生單一記錄項目
My second entry。
Logs Explorer 也提供已儲存、建議和最近的查詢。如要進一步瞭解查詢,請參閱「透過 Logs Explorer 建構查詢」。
如需查詢範例,請參閱「使用記錄檔探索工具的查詢範例」。
疑難排解
若存在打字錯誤與不明的欄位名稱,會導致 gcloud CLI 指令在完成時顯示引數無效的訊息。 舉例來說,如果您漏掉
resource.type中的句點,會導致發生錯誤:ERROR: (gcloud.logging.read) INVALID_ARGUMENT: Field not found: 'resourcetype'.若未授予 Cloud Logging 必要的存取權限,gcloud CLI 指令會在完成時顯示權限遭拒的訊息。舉例來說,如果使用預設 API 設定來設定 Compute Engine VM 執行個體,
list指令會在完成時顯示權限遭拒的錯誤:ERROR: (gcloud.logging.read) PERMISSION_DENIED: Request had insufficient authentication scopes.如要修正這個問題,請修改 Compute Engine VM 執行個體權限,授予 Cloud Logging 讀取權限,方法如下:
- 前往 VM 執行個體的「VM instance details」(VM 執行個體詳細資料) 頁面。 按一下「停止」。這個動作可能需要一兩分鐘的時間才能完成。
- 如要修改設定,請按一下 [Edit] (編輯)。
- 搜尋標頭「Cloud API 存取權範圍」,然後點選「詳細資料」,即可顯示每個 API 的設定。將項目從 Cloud Logging API 變更為「Full」(完整)。然後按一下 [儲存]。
- 如要重新啟動您的 VM 執行個體,請按一下 [Start] (啟動)。經過一段時間後,您的 VM 即準備好可供使用。
清除所用資源
為了避免系統向您的 Cloud de Confiance 帳戶收取本頁面所用資源的費用,請刪除含有這些資源的 Cloud de Confiance 專案。
(選用) 如要刪除您建立的記錄項目,請執行下列
gcloud指令:gcloud logging logs delete my-test-log
如果您不刪除記錄項目,這些項目將會到期並遭到移除。 如需保留資訊,請參閱「配額與限制」。
後續步驟
- 如要進一步瞭解 Logging 指令列介面,請參閱
gcloud logging指令群組的參考頁面。 - 如需 Logging API 的說明文件,請參閱「Cloud Logging API」。
- 如要進一步瞭解記錄檔探索工具,請參閱「使用記錄檔探索工具」。