您好,登錄后才能下訂單哦!
如何在Tye中如何進行日志的統一管理,很多新手對此不是很清楚,為了幫助大家解決這個難題,下面小編將為大家詳細講解,有這方面需求的人可以來學習下,希望你能有所收獲。
下面我們來了解一下如何在 Tye 中如何進行日志的統一管理。
對應用進行日志記錄和分析是診斷排查線上問題的重要手段。而簡單基于控制臺或者文件的直接記錄既不利于開發者直接讀取也不利于大規模分析。
因此,開發者往往會選擇一些諸如 Exceptionless
或者 ELK
之類的日志管理方案,來實現線上環境的日志管理。
但是,我們仍然缺少一個在開發環境小巧可用、部署簡易、最小資源占用、可視化良好的日志管理方案。
故而,本案例,讓我們來使用 Tye
中已經擴展可用的 Seq
工具,來作為開發環境的日志管理和可視化工具。
create-tye-seq-test.sh
dotnet new sln -n TyeTestdotnet new webapi -n TyeTestdotnet sln ./TyeTest.sln add ./TyeTest/TyeTest.csprojtye init |
通過以上命令,我們創建了一個測試的 API 項目,并且創建出了 tye.yml 文件。
直接使用 tye run
命令啟動應用,我們其實可以在 tye dashboard 中查看到查看到以控制臺方式輸出的日志:
缺陷也非常明顯,這種方式非常不利于閱讀和分析。
打開 tye.yml ,加入 seq 的擴展配置:
tye.yml
name: tyetestextensions: - name: seq logPath: ./.logsservices: - name: tyetest project: TyeTest/TyeTest.csproj |
從上面的配置可以看出:
只是增加了一個 extensions 節點。在其中設置了一個 seq 的子節點并配置了日志存儲的位置。
使用 tye run
啟動后,可以在 dashboard 中查看到啟動好的 seq 服務。
打開 seq 便可以看到 seq 的查詢界面:
這便是使用 seq 最簡單的一種方式。
seq 的搜索方式是非常類似于 SQL 的流式查詢語句,開發者可以通過以下鏈接學習如何使用 UI 進行查詢:
https://docs.datalust.co/docs/the-seq-query-language
我們都知道, Tye 在停止運行時會嘗試停止此次所有部署的容器,Seq 也是以容器的方式運行,因此,每次停止 Tye 時,容器都會被自動移除。這其實有點浪費時間。
因此,此處在進一步介紹如何在本地長久部署一個 Seq 實現重復利用。
實際上,根據 Tye 中的代碼,如果服務中已經存在一個名稱為 seq
的服務,那么就會自動使用該服務,而跳過創建步驟。
故此,我們只要本地部署一個 seq 服務,然后在 tye.yml
添加這個服務即可。
Seq 可以使用 Windows 安裝包或者使用 docker 的方式進行安裝。本示例將使用 docker 進行安裝:
docker-compose.yml
version: '3.3'services: seq: image: datalust/seq restart: always environment: ACCEPT_EULA: Y ports: - 5380:80 - 5341:5341 volumes: - ./.seqlogs:/data |
使用 docker-compose up -d
方式長久啟動 seq。那么就可以在 http://localhost:5380 查看到 seq dashboard。
然后,我們修改 tye.yml
:
tye.yml
name: tyetestextensions: - name: seqservices: - name: tyetest project: TyeTest/TyeTest.csproj - name: seq external: true bindings: - name: http containerPort: 5341 |
這里,主要的改動有:
不再需要在 extensions 中指定日志存儲此位置,因為這個時候時候的是外部的 seq 服務,指定這個參數已經沒有意義了。
添加了一個名為 seq
的服務,其中 external: true
指定了其為一個外部服務。故而啟動時不會嘗試去創建這個服務。
這樣使用 tye run
啟動后得到的結果和先前效果是一致的。但是,不會在每次都重新啟動一個新的 seq 實例。而是使用我們手動部署的 seq 實例。極大加快的啟動速度。
注意,和前面的 mongo 一樣。 seq 并不會在使用 tye deploy
時主動創建。而是會嘗試使用服務發現機制去尋找名為 seq
的服務。這其實和上節中手動創建 Seq 實例有點類似。
因此,如果要部署 extensions
包含 seq 的 tye.yml。請確保 k8s 集群中存在名稱為 seq 的服務,這樣日志才能正常輸出。
看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。