您的位置:首页技术文章
文章详情页

Crontab和Shell脚本切割Nginx日志使用详解

浏览:2日期:2023-08-07 20:15:49
目录一、配置 Crontab 定时任务二、编写 shell 脚本三、遇到的问题一、配置 Crontab 定时任务配置文件路径:/var/spool/cron/root添加定时任务59 23 * * * /root/app/shell/nginx-log-slice.sh

配置解释:在 每天的23时59分 执行 /root/app/shell/nginx-log-slice.sh 脚本。

配置其他自定义时间可以参考:Linux强大的定时任务-Crontab,有详细的配置说明。

二、编写 shell 脚本文件路径:/root/app/shell/nginx-log-slice.shnginx-log-slice.sh 完整代码#!/bin/bash. /etc/profilesource /etc/profilesource ~/.bash_profilePATH=/etc:/bin:/sbin:/usr/bin:/usr/sbin:/usr/local/bin:/usr/local/sbin# 当发生错误时中止脚本set -ebase='/usr/local/nginx/logs/'day='`date '+%Y%m%d'`'curDir='${base}${day}'accessLog=${base}access.logerrorLog=${base}error.logms='`date '+%s'`'# 判断以当天日期为名的文件夹是否存在,存在打印输出,不存在就创建if [ -d ${curDir} ];then echo '${curDir} 文件夹存在' else echo '${curDir} 文件夹不存在' mkdir ${curDir}fi# 复制当前的 access.log 和 error.log 日志文件,文件名加上时间戳,并存入以当天日期为名的文件夹\cp -rf ${accessLog} ${curDir}/access-${ms}.log\cp -rf ${errorLog} ${curDir}/error-${ms}.log# 复制完成后清空原本的 access.log 和 error.log 日志文件> ${accessLog}> ${errorLog}# 输出成功或失败的信息if [ $? == 0 ]; then echo 'nginx slice 成功 (${curDir}/access-${ms}.log)' else echo 'nginx slice 失败 (${curDir}/access-${ms}.log)'fi三、遇到的问题

问题:crontab 定时任务执行 shell 脚本时,可能遇到这种报错:/bin/sh: /root/app/shell/nginx-log-slice.sh: Permission denied,这就说明 shell 脚本权限不足。解决:执行以下命令为 nginx-log-slice.sh 文件授权。

chmod 777 /root/app/shell/nginx-log-slice.sh

使用 ll 命令查看文件权限

cd /root/app/shellll

在授权前会输出:

[root@VM-8-12-centos shell]# ll总用量 8-rwxrwxrwx 1 root root 404 10月 15 2021 test.sh-rw-r--r-- 1 root root 610 10月 9 2022 nginx-log-slice.sh

在授权后会输出:

[root@VM-8-12-centos shell]# ll总用量 8-rwxrwxrwx 1 root root 404 10月 15 2021 test.sh-rwxrwxrwx 1 root root 610 10月 9 2022 nginx-log-slice.sh

一切就绪后建议执行 nginx -s reload 重启 Nginx 服务

以上就是Crontab和Shell脚本切割Nginx日志的详细内容,更多关于Crontab Shell切割Nginx的资料请关注好吧啦网其它相关文章!

标签: Nginx