目前,容器服務Windows Kubernetes支持將業務容器產生的stdout輸出、日誌文件同步到阿里雲日誌服務(SLS)進行統一管理。
在Windows Kubernetes集群安裝界面勾選使用日誌服務,集群會安裝支持日誌收集的必要組件logtail。
使用日誌服務
logtail
k8s-sls-{Kubernetes 集群 ID}
YAML 模板的語法同 Kubernetes 語法,但是為了給容器指定採集配置,需要使用 env 來為 container 增加採集配置和自定義 Tag,並根據採集配置,創建對應的 volumeMounts 和 volumns。以下是一個簡單的 Deployment 示例:
apiVersion: extensions/v1beta1 kind: Deployment metadata: labels: app: logtail-test name: logtail-test spec: replicas: 1 template: metadata: labels: app: logtail-test name: logtail-test spec: containers: - name: logtail image: registry-vpc.cn-hangzhou.aliyuncs.com/acs/windows-logtail:1809-1.0.0.4 command: ["powershell.exe"] args: [cmd /k "ping -t 127.0.0.1 -w 10000 > C:logdata.log"] env: ######### 配置 環境變數 ########### - name: aliyun_logs_log-stdout value: stdout - name: aliyun_logs_log-varlog value: C:log*.log - name: aliyun_logs_log_tags value: tag1=v1 ################################# ######### 配置vulume mount ####### volumeMounts: - name: volumn-sls-win mountPath: c:log volumes: - name: volumn-sls-win emptyDir: {} ############################### nodeSelector: beta.kubernetes.io/os: windows
其中有三部分需要根據您的需求進行配置,一般按照順序進行配置。
aliyun_logs_
創建採集配置的規則如下:
- name: aliyun_logs_{Logstore 名稱} value: {日誌採集路徑}
示例中創建了兩個採集配置,其中 aliyun_logs_log-stdout 這個 env 表示創建一個 Logstore 名字為 log-stdout,日誌採集路徑為 stdout 的配置,從而將容器的標準輸出採集到 log-stdout 這個 Logstore 中。
說明 Logstore 名稱中不能包含下劃線(_),可以使用 - 來代替。
- name: aliyun_logs_{任意不包含_的名稱}_tags value: {Tag 名}={Tag 值}
配置 Tag 後,當採集到該容器的日誌時,會自動附加對應的欄位到日誌服務。
本例部署的應用會向data.log文件中寫入日誌。可以按以下步驟查看日誌:
本文作者:柏理
原文鏈接
更多技術乾貨敬請關注云棲社區知乎機構號:阿里云云棲社區 - 知乎
本文為雲棲社區原創內容,未經允許不得轉載。