Jeson老师写的nginx切割脚本
#Jeson
#Email:jeson@iaskjob.com
#变量定义:access、error日志文件列表
NGINX_LOG=(imoocc_com_access iaskjob_com error)
NGINX_ACCESS_PATH=/opt/logs/nginx/access
NGINX_ERROR_PATH=/opt/logs/nginx/error
#日期变量
Ydate=`date -d yesterday +%Y%m%d`
Adate=`date -d "20 days ago" +%Y%m%d`
#PID文件和nginx.conf中定义一致
Nginxpid=/opt/app/nginx/nginx.pid
#日志的量,超过此值,触发切割
Max_size=
file_size="NULL"
#函数Get_Size,获取日志文件的大小。
#rotate funcation
function Get_Size(){
logfile=$
file_size=`ls -l ${logfile}awk '{print $5}'`
if [[ $file_size =~ [-]* ]];then
echo $file_size
else
echo "error:cant get file ${logfile} size!"
exit
fi
}
#函数Log_Rotate,完成日志轮转切割。
# rename log
function Log_Rotate(){
SIZE=$
ACCESS_FILE=$
BACK_DIR=$
echo "==============$SIZE $ACCESS_FILE"
if [ $SIZE == "NULL" ];then
echo "######00000000"
if [ ! -d ${BACK_DIR} ];then
mkdir ${BACK_DIR}
fi
mv -f ${ACCESS_FILE} ${BACK_DIR}/${Ydate}.log
touch ${ACCESS_FILE}
rm ${BACK_DIR}/${Adate}.log
elif [ $SIZE -gt $Max_size ];then
echo "#######11111111"
if [ ! -d ${BACK_DIR} ];then
mkdir ${BACK_DIR}
fi
mv -f ${ACCESS_FILE} ${BACK_DIR}/${Ydate}.log
touch ${ACCESS_FILE}
rm ${BACK_DIR}/${Adate}.log
fi
}
#主功能段,作用遍历日志,输入参数为size,则按照size进行切割,如果为day,则按照日常轮转进行。
for logname in ${NGINX_LOG[@]}
do
if [ ${logname} == 'error' ];then
LOG_FILE=${NGINX_ERROR_PATH}/${logname}.log
BACK_DIR=${NGINX_ERROR_PATH}/${logname}
else
LOG_FILE=${NGINX_ACCESS_PATH}/${logname}.log
BACK_DIR=${NGINX_ACCESS_PATH}/${logname}
fi
if [ $ == "size" ];then
file_size=`Get_Size ${LOG_FILE}`
Log_Rotate ${file_size} ${LOG_FILE} ${BACK_DIR}
echo $file_size
elif [ $ == "day" ];then
Log_Rotate ${file_size} ${LOG_FILE} ${BACK_DIR}
else
echo "Param : $logname error!"
fi
done
#給nginx发送一个信号量,让nginx重载,重新重新生成日志
## restart nginx
[ ! -f $Nginxpid ] kill -USR1 $(cat $Nginxpid)
Jeson老师写的nginx切割脚本的更多相关文章
- Nginx日志定时切割脚本
nginx的日志文件如果你不处理,将变得越来越大,我们可以写一个nginx日志切割脚本来自动切割日志文件. 第一步就是重命名日志文件,不用担心重命名后nginx找不到日志文件而丢失日志.在你未重新打开 ...
- nginx切割日志脚本
nginx切割日志脚本 #!/bin/bash #cut nginx log #2018年9月26日14:26:44 #by jiajiezhao ########################## ...
- Nginx Java 日志切割脚本
Nginx日志切割脚本: #!/bin/bash ########################################################################### ...
- nginx学习笔记(四)-----日志切割脚本及定时任务
一.日志切割脚本 #!/bin/sh #nginx目录 BASE_DIR=/usr/local/nginx #生成的日志 BASE_FILE_NAME=jonychen.access.log CURR ...
- shell按日期自动切割nginx日志脚本
shell按日期自动切割nginx日志脚本 参考:自学it网 http://www.zixue.it/. #nginx日志切割脚本 #author:ce #!/bin/bash #设置日志文件存放目录 ...
- nginx日志按日期自动切割脚本
#!/bin/bash #nginx日志切割脚本 #author:setevn #设置日志文件存放目录 logs_path="/usr/local/nginx/logs/" #设置 ...
- linux Nginx 日志脚本
这篇文章主要介绍了nginx日志切割脚本.nginx日志分析脚本等,需要的朋友可以参考下. 参考自:http://www.jbxue.com/article/13927.html 任务计划 cront ...
- 如何写SysV服务管理脚本
本文目录: 1.1 SysV脚本的特性1.2 SysV脚本要具备的能力1.3 start函数分析1.4 stop函数分析1.5 reload函数分析1.6 status.restart.force-r ...
- Ubuntu 16.04开机自启Nginx简单脚本
本文要记述的是最简单的Ubuntu下开机自启 nginx的脚本 这里将nginx装在了/usr/local/nginx目录下,nginx本身没有注册成服务,所以直接使用服务开机自启是不行的,除非自己写 ...
随机推荐
- 团队Alpha冲刺(四)
目录 组员情况 组员1(组长):胡绪佩 组员2:胡青元 组员3:庄卉 组员4:家灿 组员5:凯琳 组员6:丹丹 组员7:何家伟 组员8:政演 组员9:鸿杰 组员10:刘一好 组员:何宇恒 展示组内最新 ...
- slf4j与logback的结合使用
参考:http://my.oschina.net/ydsakyclguozi/blog/412240 一.logback的介绍 Logback是由log4j创始人设计的又一个开源日志组件.logbac ...
- PAT 甲级 1054 The Dominant Color
https://pintia.cn/problem-sets/994805342720868352/problems/994805422639136768 Behind the scenes in t ...
- LR之Java Vuser II
最近项目待压测的服务端协议使用的是java的Netty框架开发,而传输的业务数据使用了google protobuf进行序列化,然后通过tcp数据流与客户端通讯.这一次的压测脚本决定使用LR的java ...
- css & text-overflow & ellipsis
css & text-overflow & ellipsis https://developer.mozilla.org/en-US/docs/Web/CSS/text-overflo ...
- Kafka在大型应用中的 20 项最佳实践
原标题:Kafka如何做到1秒处理1500万条消息? Apache Kafka 是一款流行的分布式数据流平台,它已经广泛地被诸如 New Relic(数据智能平台).Uber.Square(移动支付公 ...
- TCP建立连接与释放连接过程中的几个问题
TCP为何采用三次握手来建立连接,若采用两次握手可以吗,请说明理由? 不可以.采用三次握手是为了防止失效的连接请求报文段突然又传送到服务器,从而发生错误.当客户端发出的连接请求报文段由于某些原因没有及 ...
- 【数据库_Mysql】MySQL—修改表时给表添加联合主键约束
添加语法如下: “ALTER TABLE table_name ADD CONSTRAINT pk_table_name PRIMARY KEY(列名1,列名2):” [示例1]假设订房信息表(O ...
- BZOJ4878 挑战NP-Hard(dfs树)
既然是二选一,考虑两个问题有什么联系.题面没有说无解怎么办,所以如果不存在经过k条边的简单路径,一定存在k染色方案.考虑怎么证明这个东西,我们造一棵dfs树.于是可以发现如果树深>k(根节点深度 ...
- 洛谷 P3177 树上染色
题面 题目要求将k个点染成黑色,求黑点两两距离及白点两两距离,使他们之和最大. 我们可以将距离转化为路径,然后再将路径路径拆分成边,就可以记录每条边被经过的次数,直接计算即可. 很简单对吧?那么问题来 ...