日本熟妇hd丰满老熟妇,中文字幕一区二区三区在线不卡 ,亚洲成片在线观看,免费女同在线一区二区

通過SLS CRD采集日志

本文介紹在ACK Serverless集群中,如何通過SLS CRD來配置日志采集,實現(xiàn)通過阿里云日志服務SLS自動采集容器日志。

背景信息

阿里云日志服務SLS(Log Service)是針對日志數(shù)據(jù)的一站式服務,您無需開發(fā)就能快捷完成日志數(shù)據(jù)采集、消費、投遞以及查詢分析等功能。更多信息,請參見日志服務簡介

前提條件

已開通日志服務。登錄日志服務控制臺時,如果沒有開通日志服務,將收到相關提示,您可以根據(jù)頁面提示開通。

注意事項

通過SLS CRD開啟日志采集僅對后續(xù)創(chuàng)建的ECI Pod生效。如果想要采集存量Pod的日志,需要對存量Pod進行一次滾動發(fā)布。

配置日志采集

在集群內部署alibaba-log-controller組件后,您可以通過日志采集配置CRD(AliyunLogConfig CRD)來配置日志采集。

部署alibaba-log-controller組件

  1. 登錄容器服務管理控制臺

  2. 集群頁面,單擊目標集群名稱,進入集群管理頁面。

  3. 在集群中部署alibaba-log-controller組件。

    1. 在集群管理頁左側導航欄,選擇運維管理>組件管理

    2. 單擊日志與監(jiān)控頁簽,找到alibaba-log-controller卡片,然后單擊安裝

    3. 在彈出的對話框中,單擊確定

      安裝完成后,alibaba-log-controller卡片右上角會顯示已安裝。

創(chuàng)建Logtail采集配置

  1. 連接ACK Serverless集群。

  2. 編寫日志采集配置CRD的YAML配置文件。

    重要

    創(chuàng)建日志采集配置CRD后,您可以在日志服務控制臺查看生成的日志庫及l(fā)ogtail配置。通過CRD方式創(chuàng)建的配置,在控制臺上對其修改不會同步到CRD中。如果后續(xù)需要更新配置,請直接修改CRD資源,不要在控制臺操作,避免導致配置不一致。

    AliyunLogConfig CRD YAML模板

    apiVersion: log.alibabacloud.com/v1alpha1     
    kind: AliyunLogConfig                         
    metadata:
      name: simple-stdout-example                 
    spec:
      project: k8s-my-project                      
      logstore: k8s-stdout                         
      logstoreMode: standard                       
      shardCount: 2                               
      lifeCycle: 90                               
      logtailConfig:                            
        inputType: plugin                          
        configName: simple-stdout-example          
        inputDetail:                               
          ...
    • 基本參數(shù)

      參數(shù)

      類型

      是否必填

      說明

      project

      string

      Project名稱。默認為安裝Logtail組件時設置的Project。

      如果要新建Project,可自定義輸入名稱,如果不存在該Project,系統(tǒng)會自動新建。

      logstore

      string

      Logstore名稱。如果您所指定的Logstore不存在,系統(tǒng)會自動創(chuàng)建。

      logstoreMode

      string

      Logstore類型。該參數(shù)值僅在新建Logstore時生效。取值范圍:

      • query:查詢型Logstore。

      • standard:標準型Logstore。

      更多信息,請參見管理Logstore

      shardCount

      int

      Shard數(shù)量。默認值為2,取值范圍為1~10。

      lifeCycle

      int

      Logstore中數(shù)據(jù)的存儲時間。默認值為90,取值范圍為1~3650。其中,3650天為永久存儲。該參數(shù)值僅在新建Logstore時生效。

      machineGroups

      array

      機器組。安裝Logtail組件時,日志服務會自動創(chuàng)建名為k8s-group-${your_k8s_cluster_id}的機器組。

      logtailConfig

      object

      Logtail配置。包含以下參數(shù):

      • configName:Logtail配置的名稱。必須與metadata.name相同。

      • inputType:日志輸入的方式。可選值如下:

        • plugin:通過Logtail插件采集MySQL Binlog等日志。

        • file:通過固定模式(正則模式、分隔符模式等)采集文本文件中的日志。

      • inputDetail:日志輸入的相關配置。

      • outputType:日志輸出的方式,只支持LogService,即只支持將數(shù)據(jù)上傳到日志服務。

      • outputDetail:日志輸出的相關配置。

      • logSample:日志樣例。

      詳細的參數(shù)說明請參見Logtail配置

    • 容器過濾

      • Logtail 1.0.34以下版本,只支持通過環(huán)境變量、容器Label進行容器過濾。

        Kubernetes中的命名空間名和容器名會映射到容器Label中,分別為io.kubernetes.pod.namespaceio.kubernetes.container.name。推薦使用這兩個容器Label進行容器過濾。如果這兩個容器Label未滿足需求,請使用環(huán)境變量的黑白名單進行容器過濾。

      • Logtail 1.0.34及以上版本,可以使用Kubernetes層級的信息(Pod名稱、Namespace、容器名稱、容器Label等)進行容器過濾。

        容器過濾參數(shù)請配置在logtailConfig>inputDetail>advanced>k8s字段下。支持的參數(shù)如下:

        • IncludeK8sLabel:Kubernetes Label白名單,用于指定待采集的容器。

        • ExcludeK8sLabel:Kubernetes Label黑名單,用于排除不采集的容器。

        • K8sNamespaceRegex:指定Namespace。

        • K8sPodRegex:指定Pod名稱。

        • K8sContainerRegex:指定容器名稱。

    更多信息,請參見通過DaemonSet方式采集Kubernetes容器文本日志通過DaemonSet方式采集Kubernetes容器標準輸出

    AliyunLogConfig CRD YAML示例

    文本日志CRD YAML示例

    將以下內容保存為log-file.yaml

    apiVersion: log.alibabacloud.com/v1alpha1  # 使用默認值,無需修改。
    kind: AliyunLogConfig                      # 使用默認值,無需修改。
    metadata:
      name: test-file                  # 資源名,在當前Kubernetes集群內唯一。
    spec:
      project: k8s-log-c326bc86****    # 可選配置,Project名稱,如果不存在該Project,系統(tǒng)會自動新建
      logstore: test-file              # 必選配置,Logstore名稱,如果不存在該Logstore,系統(tǒng)會自動創(chuàng)建   
      logtailConfig:                   # Logtail配置
        inputType: file                # 采集的數(shù)據(jù)源類型,file表示文本日志,plugin表示標準輸出
        configName: test-file          # Logtail配置的名稱,必須與資源名(metadata.name)相同 
        inputDetail:                   # Logtail配置的詳細信息
          logType: common_reg_log      # 通過極簡模式采集文本日志
          logPath: /log/               # 日志文件所在路徑
          filePattern: "*.log"         # 日志文件的名稱,支持通配符星號(*)和半角問號(?),例如log_*.log。
          dockerFile: true             # 采集容器內的文件,dockerFile設置為true
          advanced:                    # 設置容器過濾條件
            k8s:
              K8sNamespaceRegex: ^(default)$
              K8sPodRegex: '^(eci-sls-demo.*)$'

    標準輸出CRD YAML示例

    將以下內容保存為log-stdout.yaml。

    apiVersion: log.alibabacloud.com/v1alpha1   # 使用默認值,無需修改。
    kind: AliyunLogConfig                       # 使用默認值,無需修改。
    metadata:
      name: test-stdout               # 資源名,在當前Kubernetes集群內唯一。
    spec:
      project: k8s-log-c326bc86****   # 可選配置,Project名稱,如果不存在該Project,系統(tǒng)會自動新建
      logstore: test-stdout           # 必選配置,Logstore名稱,如果不存在該Logstore,系統(tǒng)會自動創(chuàng)建                  
      shardCount: 2                   # 可選配置,Shard數(shù)量,默認為2,取值范圍為1~10                         
      lifeCycle: 90                   # 可選配置,Logstore中日志保留時間,單位為天,該參數(shù)值僅在新建Logstore時生效。默認為90,取值范圍為1~3650。3650表示永久保留
      logtailConfig:                  # Logtail配置
        inputType: plugin             # 采集的數(shù)據(jù)源類型,file表示文本日志,plugin表示標準輸出                                
        configName: test-stdout       # Logtail配置的名稱,必須與資源名(metadata.name)相同 
        inputDetail:                  # Logtail配置的詳細信息
          plugin:
            inputs:
              - type: service_docker_stdout
                detail:
                  Stdout: true
                  Stderr: true
    #              IncludeEnv:
    #                aliyun_logs_test-stdout: "stdout"
  3. 創(chuàng)建日志采集配置CRD。

    命令示例如下。Logtail配置生效后,Logtail開始采集各個容器上的標準輸出或文本日志,并發(fā)送到日志服務中。

    kubectl apply -f log-file.yaml
    kubectl apply -f log-stdout.yaml
    重要

    采集到日志后,您需要先創(chuàng)建索引,才能在Logstore中查詢和分析日志。具體操作,請參見創(chuàng)建索引

測試日志采集

創(chuàng)建日志采集配置CRD后,日志服務會自動采集后續(xù)創(chuàng)建的Pod的日志。您可以創(chuàng)建以下應用來測試日志采集效果。

  1. 創(chuàng)建應用。

    以Deployment為例,YAML內容示例如下,示例中容器啟動后會執(zhí)行相關命令,不斷打印標準輸出和日志文件。

    apiVersion: apps/v1
    kind: Deployment
    metadata:
      name: eci-sls-demo
      labels:
        app: sls
    spec:
      replicas: 1
      selector:
        matchLabels:
          app: sls
      template:
        metadata:
          name: sls-test
          labels:
            app: sls
            alibabacloud.com/eci: "true" 
        spec:
          containers:
          - args:
            - -c
            - mkdir -p /log;while true; do echo hello world; date; echo hello sls >> /log/busy.log; sleep 1;done
            command:
            - /bin/sh
            image: registry-vpc.cn-beijing.aliyuncs.com/eci_open/busybox:1.30
            imagePullPolicy: Always
            name: busybox

    將以上YAML保存為test-sls-crd.yaml,執(zhí)行以下命令創(chuàng)建應用。

    kubectl create -f test-sls-crd.yaml
  2. 確認應用狀態(tài)。

    kubetcl get pod

    預期返回:

    NAME                            READY   STATUS    RESTARTS   AGE
    eci-sls-demo-7bf8849b9f-cgpbn   1/1     Running   0          2m14s
  3. 查看日志。

    1. 登錄日志服務控制臺

    2. 單擊目標Project名稱。

    3. 找到目標日志庫,單擊日志庫名稱查看日志。

      文本日志

      日志crd1

      標準輸出

      日志crd0

關閉日志采集

創(chuàng)建日志采集配置CRD后,系統(tǒng)會自動采集所有符合條件的Pod的日志。對于一些不想要采集日志的Pod,您可以配置Annotation(k8s.aliyun.com/eci-sls-enable: "false")來關閉日志采集,避免系統(tǒng)自動創(chuàng)建Logtail而造成資源浪費。

重要
  • Annotation請?zhí)砑釉赑od的metadata下,例如:創(chuàng)建Deployment時,Annotation需添加在spec>template>metadata下。

  • 僅支持在創(chuàng)建ECI Pod時添加ECI相關Annotation來生效ECI功能,更新ECI Pod時添加或者修改ECI相關Annotation均不會生效。

配置示例如下:

apiVersion: apps/v1
kind: Deployment
metadata:
  name: eci-sls-demo2
  labels:
    app: sls
spec:
  replicas: 1
  selector:
    matchLabels:
      app: sls
  template:
    metadata:
      name: sls-test
      labels:
        app: sls
        alibabacloud.com/eci: "true"
      annotations:
        k8s.aliyun.com/eci-sls-enable: "false"    #關閉日志采集
    spec:
      containers:
      - args:
        - -c
        - mkdir -p /log;while true; do echo hello world; date; echo hello sls >> /log/busy.log; sleep 1;
          done
        command:
        - /bin/sh
        image: registry.cn-shanghai.aliyuncs.com/eci_open/busybox:1.30
        imagePullPolicy: Always
        name: busybox