欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

docker部署nginx下日志自動切割方法實現(xiàn)

 更新時間:2024年10月17日 10:55:25   作者:南山老沙  
部署Nginx在Docker中時,其日志文件默認不會自動切割,與非Docker環(huán)境有所不同,本文介紹了三種日志切割方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

前言

nginx采用docker部署,簡單方便,但出現(xiàn)一個問題,就是日志沒有自動切割,導(dǎo)致access.log 無限增大。如果非docker安裝,則nginx的日志默認有切割的,那docker為何沒有呢,最后發(fā)現(xiàn),nginx容器里面沒有 logrotate 服務(wù)(logrotate: command not found)

服務(wù)器環(huán)境:centos 7
nginx的docker運行命令:

docker run -d --name nginx --restart always --net host -v /opt/common/nginx/nginx.conf:/etc/nginx/nginx.conf -v /opt/common/nginx/html:/usr/share/nginx/html -v /opt/common/nginx/logs:/var/log/nginx -v /opt/common/nginx/conf.d:/etc/nginx/conf.d -e TZ="Asia/Shanghai" nginx:1.24.0

其中服務(wù)器本地日志映射目錄是 /opt/common/nginx/logs

以下搜集了幾種日志切割方式:

  • 1 nginx配置map日期
  • 2 腳本切割
  • 3 配置 logrotate

1 nginx配置map日期

在 nginx/conf.d 目錄下,新建 logdate.conf 文件(nginx重啟會自動加載的)
內(nèi)容是:

map $time_iso8601 $logdate {
    default 'date-not-found';
    '~^(?<ymd>\d{4}-\d{2}-\d{2})' $ymd;
}

然后在 nginx.conf 的日志配置如下:

access_log  /var/log/nginx/access-$logdate.log  main;

原來的默認配置是:

access_log /var/log/nginx/access.log main;

這時到了第二天就會自動生成新的log文件
注意:映射 出來的存log的文件夾logs需要配一下權(quán)限,因為nginx要創(chuàng)建文件需要權(quán)限

例如:賦給nginx權(quán)限

chown -R nginx:nginx logs

生成之后,文件長這樣:

在這里插入圖片描述

該方法是按每天歸整,缺點是每次打日志會走map一次日期,會犧牲一點點性能,此外,定期清理日志,需要再額外寫個清理腳本(只保留N天,騰出存儲空間),切割日志目的之一就是為了方便清理日志

2 腳本切割

該方法是寫個腳本,定時凌晨12點將日志切割歸檔,這個方法相對比較簡單

#!/bin/bash
LOGS_PATH=$1
DAYS=$2
YESTERDAY=$(date -d "yesterday" +%Y-%m-%d)
#按天切割日志
mv ${LOGS_PATH}/access.log ${LOGS_PATH}/access_${YESTERDAY}.log
#向 Nginx 主進程發(fā)送 USR1 信號,重新打開日志文件,否則會繼續(xù)往mv后的文件寫內(nèi)容,導(dǎo)致切割失敗.
kill -USR1 `ps axu | grep "nginx: master process" | grep -v grep | awk '{print $2}'`
#刪除配置的N天前的日志
cd ${LOGS_PATH}
find . -mtime +${DAYS} -name "*20[1-9][3-9]*" | xargs rm -f
exit 0

將該腳本保存到 cut_nginx_log.sh,找個地方放,例如放在
/opt/common/nginx/logs/cut_nginx_log.sh

給該文件增加執(zhí)行權(quán)限:
chmod +x /opt/common/nginx/logs/cut_nginx_log.sh

然后編輯定時任務(wù):
crontab -e

編輯寫入:

01 00 * * * /opt/common/nginx/logs/cut_nginx_log.sh /opt/common/nginx/logs/ 120

這個定時任務(wù)是,每天凌晨01秒,開始執(zhí)行該腳本,腳本第一個參數(shù) /opt/common/nginx/logs/ 表示日志的目錄,第二個參數(shù)120表示日志保留120天,即清理120天之前的日志

這個方法是切割與定期清理一起,比較簡單方便

3 配置 logrotate

既然nginx容器里面的 logrotate 服務(wù)不可用,那么就利用docker宿主機的 logrotate 服務(wù),這個服務(wù)是 centos7 默認安裝的,即利用服務(wù)器本地的 logrotate。
將以下腳本保存在 /etc/logrotate.d/nginx (vi /etc/logrotate.d/nginx,然后將以下腳本復(fù)制進去)

/opt/common/nginx/logs/*.log {
        daily
        missingok
        rotate 52
        compress
        delaycompress
        notifempty
        create 640 nginx adm
        sharedscripts
        postrotate
                kill -USR1 `ps axu | grep "nginx: master process" | grep -v grep | awk '{print $2}'`
        endscript
}

然后添加定時任務(wù):

echo “59 23 * * * /usr/sbin/logrotate -f /etc/logrotate.d/nginx >/dev/null 2>&1” > /etc/crontab

或者執(zhí)行 crontab -e ,然后將以下編輯寫入

59 23 * * * /usr/sbin/logrotate -f /etc/logrotate.d/nginx >/dev/null 2>&1

這個定時任務(wù)是,每天23:59 開始切割,并做壓縮
結(jié)果是:

在這里插入圖片描述

此外,error.log 也會切割,其中腳本具體參數(shù)意義在此不做詳述

最后總結(jié):

以上三種,腳本方式是比較簡單,可根據(jù)情況進行配置,選其一即可,更多相關(guān)docker nginx日志自動切割內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • linux中docker的安裝教程

    linux中docker的安裝教程

    這篇文章主要介紹了linux中docker的安裝教程,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2020-10-10
  • 一文詳解如何修改Docker的默認存儲路徑

    一文詳解如何修改Docker的默認存儲路徑

    這篇文章主要介紹了關(guān)于如何修改Docker的默認存儲路徑的相關(guān)資料,默認安裝的情況下,會使用 /var/lib/docker/ 目錄作為存儲目錄,用以存放拉取的鏡像和創(chuàng)建的容器等,這個路徑是系統(tǒng)存儲目錄,一般空間會比較小,需要的朋友可以參考下
    2023-08-08
  • Docker存儲目錄問題以及如何修改Docker默認存儲位置

    Docker存儲目錄問題以及如何修改Docker默認存儲位置

    在Docker中,默認情況下數(shù)據(jù)存儲路徑為/var/lib/docker,隨著容器和鏡像數(shù)量的增加,這可能會占用大量磁盤空間,這篇文章主要給大家介紹了關(guān)于Docker存儲目錄問題以及如何修改Docker默認存儲位置的相關(guān)資料,需要的朋友可以參考下
    2024-08-08
  • Docker 教程之Docker Hub詳細介紹

    Docker 教程之Docker Hub詳細介紹

    這篇文章主要介紹了Docker 教程之Docker Hub詳細介紹的相關(guān)資料,需要的朋友可以參考下
    2016-12-12
  • Docker安裝Presto連接Hive的詳細過程

    Docker安裝Presto連接Hive的詳細過程

    這篇文章主要介紹了Docker安裝Presto連接Hive的詳細過程,本文給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-09-09
  • docker安裝tomcat dubbo-admin實例技巧

    docker安裝tomcat dubbo-admin實例技巧

    在本篇文章里小編給大家整理的是關(guān)于docker安裝tomcat dubbo-admin實例技巧,有需要的朋友們可以參考下。
    2020-01-01
  • Docker進階之快速擴容的方法

    Docker進階之快速擴容的方法

    這篇文章主要介紹了Docker進階之快速擴容的方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-08-08
  • 基于docker 搭建Prometheus+Grafana的過程詳解

    基于docker 搭建Prometheus+Grafana的過程詳解

    這篇文章主要介紹了基于docker 搭建Prometheus+Grafana的過程詳解,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2021-03-03
  • Docker網(wǎng)段和內(nèi)網(wǎng)網(wǎng)段ip沖突導(dǎo)致無法訪問網(wǎng)絡(luò)的兩種解決方法

    Docker網(wǎng)段和內(nèi)網(wǎng)網(wǎng)段ip沖突導(dǎo)致無法訪問網(wǎng)絡(luò)的兩種解決方法

    本文主要介紹了Docker網(wǎng)段和內(nèi)網(wǎng)網(wǎng)段沖突導(dǎo)致無法訪問網(wǎng)絡(luò)的兩種解決方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2023-06-06
  • docker容器時區(qū)錯誤問題

    docker容器時區(qū)錯誤問題

    常出現(xiàn)docker中運行的容器獲取到的時間與北京時間相差8小時的問題,其實是因為容器運行的時區(qū)不正確。本文主要介紹了docker容器時區(qū)錯誤問題,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-12-12

最新評論