中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

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

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

云計算中如何對容器實例日志設置定期清理和回卷

發布時間:2021-11-19 09:30:57 來源:億速云 閱讀:137 作者:小新 欄目:云計算

小編給大家分享一下云計算中如何對容器實例日志設置定期清理和回卷,希望大家閱讀完這篇文章之后都有所收獲,下面讓我們一起去探討吧!

引言

Kubernetes對于容器實例的日志收集,并沒有提供原生的解決方案。但提供使用kubectl logs命令查看容器實例運行時的日志。kubectl logs命令實現的基本原理為:容器運行時默認將標準輸出和標準錯誤中的日志輸出到磁盤上保存。保存至主機目錄:/var/lib/docker/containers/container_id/目錄。用戶調用kubectl logs命令時,kubelet讀取對應的日志文件中的數據,將數據回傳給master,再由master返回到用戶。從而實現用戶對日志的查看。

騰訊云容器服務利用kubectl logs命令,實現在控制臺即可查看對應容器實例的日志,并且提供查看某個特定時間段的日志的功能,這極大的方便了用戶對容器實例中的程序進行定位和跟蹤。但是,由于在容器實例日志保存在本地,當程序中大量打印日志時,很容易造成主機上的磁盤空間大量被占用。在日志服務上線一段時間后,發現用戶遇到這種情況時,一般是手動去清理日志。我們就考慮是不是有比較簡單的方式,在集群節點對日志進行定期清理和回卷。

通過logrotate服務實現日志定期清理和回卷

logrotate是個十分有用的工具,它可以自動對日志進行截斷(或輪循)、壓縮以及刪除舊的日志文件。例如,你可以設置logrotate,讓/var/log/foo日志文件每30天輪循,并刪除超過6個月的日志。配置完后,logrotate的運作完全自動化,不必進行任何進一步的人為干預。
但如果按照之前的部署方式,需要手動在每個節點上都安裝和配置對應logrotate工具。如果通過Kubernetes容器服務編排的能力,將logrotate通過Kubernetes中服務的方式部署到各個節點上,這樣既可以實現只需要一次部署,部署到所有節點。并且通過容器的方式保證了logrotate配置的一致性。

具體的實施方案如下圖所示:

云計算中如何對容器實例日志設置定期清理和回卷

方案的具體實現是在Kubernetes集群中,創建DaemonSet資源實現。DaemonSet資源會在每個Node節點上都部署一個logrotate的容器實例,并且在容器實例中設置映射主機的log日志目錄,從而實現日志的定時清理和回卷。

創建DaemonSet的示例如下

apiVersion: extensions/v1beta1
kind: DaemonSet
metadata:
  name: logrotate
spec:
  template:
    metadata:
      labels:
        app: logging
        id: logrotate
      name: logrotate
    spec:
      containers:
      - name: logrotate-es
        image: blacklabelops/logrotate
        securityContext:
          privileged: true
        volumeMounts:
         - name: containers
           mountPath: /var/lib/docker/containers
         - name: varlog
           mountPath: /var/log/docker
         - name: logs
           mountPath: /logs
        env:
        - name: LOGS_DIRECTORIES
          value: "/var/lib/docker/containers /var/log/docker"
        - name: LOGROTATE_INTERVAL
          value: "hourly"
        - name: LOGROTATE_OLDDIR
          value: "/logs"
      volumes:
         - hostPath:
             path: /var/lib/docker/containers
           name: containers
         - hostPath:
             path: /var/log/docker
           name: varlog
         - hostPath:
             path: /var/log/containers/
           name: logs

使用這個yaml文件,可以直接在Kubernetes中進行部署。

# kubectl create -f logrotate_ds.yaml
daemonset "logrotate">

在示例的yaml文件中,logrotate服務將按照定時(1小時)的對日志進行回卷,回卷超過5個副本后則會對日志進行清理。如果有需要,可以修改相應的參數,設置不同的回卷規則和清理規則。詳細的參數說明可以參考:https://github.com/blacklabelops/logrotate。

通過修改dockerd參數進行回卷和清理

由于Kubernetes的日志收集,底層是通過docker來實現。而docker提供了一定的日志回卷和清理功能。可以通過在dockerd的啟動參數中,增加log-opts()參數實現對日志的回卷和清理,其中max-size參數設置日志一個副本的最大值,max-file設置日志的最大的副本數。超過這個副本數則會對日志進行刪除。

具體的修改過程包括三個步驟:
1、創建/etc/dockerd/daemon.json

{
  "log-driver":"json-file",
  "log-opts":{
    "max-size" :"10m","max-file":"3"
    }
}

參數說明: 設置單個容器日志超過10M則進行回卷,回卷的副本數超過3個就進行清理。

2、修改dockerd 服務配置文件
在 /etc/systemd/system/multi-user.target.wants/dockerd.serviced文件中
添加dockerd啟動參數--config-file=/etc/docker/daemon.json

3、重新啟動dockerd服務

systemctl daemon-reload
service dockerd restart

看完了這篇文章,相信你對“云計算中如何對容器實例日志設置定期清理和回卷”有了一定的了解,如果想了解更多相關知識,歡迎關注億速云行業資訊頻道,感謝各位的閱讀!

向AI問一下細節

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

AI

丰城市| 桑植县| 若尔盖县| 奇台县| 特克斯县| 禹州市| 准格尔旗| 家居| 绿春县| 普定县| 辽源市| 香港| 赫章县| 安福县| 大厂| 甘南县| 禄丰县| 南郑县| 皋兰县| 利川市| 绥宁县| 合山市| 湖南省| 平南县| 高州市| 嵊泗县| 虹口区| 吕梁市| 贵阳市| 龙山县| 扎兰屯市| 满洲里市| 田阳县| 开封市| 秀山| 德江县| 苍南县| 谷城县| 正定县| 广安市| 淳安县|