亚洲激情专区-91九色丨porny丨老师-久久久久久久女国产乱让韩-国产精品午夜小视频观看

溫馨提示×

溫馨提示×

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

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

如何在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

呈贡县| 忻城县| 进贤县| 孙吴县| 阜新市| 石楼县| 土默特左旗| 麻阳| 大渡口区| 晋中市| 电白县| 宕昌县| 晋城| 恩施市| 贡嘎县| 汪清县| 肇源县| 明光市| 汨罗市| 宁都县| 沂水县| 临沂市| 无锡市| 乌兰浩特市| 红原县| 柘荣县| 壶关县| 堆龙德庆县| 仁布县| 孟州市| 奇台县| 石狮市| 饶阳县| 甘德县| 青阳县| 绿春县| 津南区| 昌邑市| 玉环县| 德昌县| 桑日县|