乐趣区

容器服务Windows-Kubernetes使用阿里云日志服务来收集容器日志

目前,容器服务 Windows Kubernetes 支持将业务容器产生的 stdout 输出、日志文件同步到阿里云日志服务(SLS)进行统一管理。

支撑组件安装

在 Windows Kubernetes 集群安装界面勾选 使用日志服务,集群会安装支持日志收集的必要组件logtail

集群安装完毕后,可以在日志服务控制台 查看到按 k8s-sls-{Kubernetes 集群 ID} 形式命名的工程。收集到的业务容器日志都会放在该工程下。

使用 YAML 模版部署业务容器

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:\log\data.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

其中有三部分需要根据您的需求进行配置,一般按照顺序进行配置。

  • 第一部分通过环境变量来创建您的采集配置和自定义 Tag,所有与配置相关的环境变量都采用 aliyun_logs_ 作为前缀。
    创建采集配置的规则如下:
- name: aliyun_logs_{Logstore 名称}
  value: {日志采集路径}

示例中创建了两个采集配置,其中 aliyun_logs_log-stdout 这个 env 表示创建一个 Logstore 名字为 log-stdout,日志采集路径为 stdout 的配置,从而将容器的标准输出采集到 log-stdout 这个 Logstore 中。

说明 Logstore 名称中不能包含下划线(_),可以使用 – 来代替。

  • 创建自定义 Tag 的规则如下:
- name: aliyun_logs_{任意不包含 '_' 的名称}_tags
  value: {Tag 名}={Tag 值}

配置 Tag 后,当采集到该容器的日志时,会自动附加对应的字段到日志服务。

  • 如果您的采集配置中指定了非 stdout 的采集路径,需要在此部分创建相应的 volumnMounts。
    示例中采集配置添加了对 c:log*.log 的采集,因此相应地添加了 c:log 的 volumeMounts。

查看日志

本例部署的应用会向 data.log 文件中写入日志。可以按以下步骤查看日志:

  1. 安装成功后,进入日志服务控制台。
  2. 在进入控制台后,选择 Kubernetes 集群对应的 Project(默认为 k8s-log-{Kubernetes 集群 ID}),进入 Logstore 列表页面。
  3. 在列表中找到相应的 Logstore(采集配置中指定),单击 查询

  1. 本例中,在日志查询页面,您可查看容器内文本日志,并可发现自定义 tag 附加到日志字段中。


本文作者:柏理

阅读原文

本文为云栖社区原创内容,未经允许不得转载。

退出移动版