91超碰碰碰碰久久久久久综合_超碰av人澡人澡人澡人澡人掠_国产黄大片在线观看画质优化_txt小说免费全本

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

如何在Tye中如何進行日志的統一管理

發布時間:2021-12-16 10:13:36 來源:億速云 閱讀:140 作者:柒染 欄目:云計算

如何在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中如何進行日志的統一管理

缺陷也非常明顯,這種方式非常不利于閱讀和分析。

啟用 Seq 記錄和查看日志

打開 tye.yml ,加入 seq 的擴展配置:

tye.yml

name: tyetestextensions:  - name: seq    logPath: ./.logsservices:  - name: tyetest    project: TyeTest/TyeTest.csproj

從上面的配置可以看出:

  1. 只是增加了一個 extensions 節點。在其中設置了一個 seq 的子節點并配置了日志存儲的位置。

使用 tye run 啟動后,可以在 dashboard 中查看到啟動好的 seq 服務。

如何在Tye中如何進行日志的統一管理

打開 seq 便可以看到 seq 的查詢界面:

如何在Tye中如何進行日志的統一管理

這便是使用 seq 最簡單的一種方式。

seq 的搜索方式是非常類似于 SQL 的流式查詢語句,開發者可以通過以下鏈接學習如何使用 UI 進行查詢:

https://docs.datalust.co/docs/the-seq-query-language

我不想每次都重新部署 Seq

我們都知道, 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

這里,主要的改動有:

  1. 不再需要在 extensions 中指定日志存儲此位置,因為這個時候時候的是外部的 seq 服務,指定這個參數已經沒有意義了。

  2. 添加了一個名為 seq 的服務,其中 external: true 指定了其為一個外部服務。故而啟動時不會嘗試去創建這個服務。

這樣使用 tye run 啟動后得到的結果和先前效果是一致的。但是,不會在每次都重新啟動一個新的 seq 實例。而是使用我們手動部署的 seq 實例。極大加快的啟動速度。

注意,和前面的 mongo 一樣。 seq 并不會在使用 tye deploy 時主動創建。而是會嘗試使用服務發現機制去尋找名為 seq 的服務。這其實和上節中手動創建 Seq 實例有點類似。

因此,如果要部署 extensions 包含 seq 的 tye.yml。請確保 k8s 集群中存在名稱為 seq 的服務,這樣日志才能正常輸出。

看完上述內容是否對您有幫助呢?如果還想對相關知識有進一步的了解或閱讀更多相關文章,請關注億速云行業資訊頻道,感謝您對億速云的支持。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

tye
AI

池州市| 新泰市| 隆尧县| 怀化市| 襄垣县| 怀安县| 乌什县| 延寿县| 黎平县| 清徐县| 仙桃市| 思南县| 若尔盖县| 柯坪县| 永年县| 瑞昌市| 镇平县| 东源县| 云阳县| 彭山县| 仙居县| 陇南市| 洛扎县| 茌平县| 长沙市| 太白县| 锡林郭勒盟| 靖江市| 岳阳市| 兴宁市| 安阳市| 丰都县| 安顺市| 即墨市| 新绛县| 乌兰察布市| 农安县| 新晃| 万州区| 边坝县| 长垣县|