发表于: 2017-10-04 23:35:34
1 838
今天完成的事情:
看之前写的日报,
初学时语法基础, 对象继承调用创建,做任务时遇到的问题,都可以加深现在对代码的理解.
今天把脚本的nginx响应时间给写了出来.
echo "响应时间20ms以内" >>time.txt
cat /usr/local/nginx/logs/access.log | awk 'BEGIN{sum=0}{if($9<20) sum++;} END{print sum}' >> time.txt
echo "响应时间在20ms-100ms" >> time.txt
cat /usr/local/nginx/logs/access.log | awk 'BEGIN{sum=0}{if(($9>=20)&&($9<100)) sum++} END{print sum}' >> time.txt
echo "响应时间在100ms-200ms" >> time.txt
cat /usr/local/nginx/logs/access.log | awk 'BEGIN{sum=0}{if(($9>=100)&&($9<200)) sum++} END{print sum}' >> time.txt
echo "响应时间在200ms以外" >> time.txt
cat /usr/local/nginx/logs/access.log | awk 'BEGIN{sum=0}{if($9>200) sum++;}END{print sum} END{print sum}' >> time.txt
#nginx日志切割脚本
#!/bin/bash
#设置日志文件存放目录
logs_path="/usr/local/nginx/logs/"
#设置pid文件
pid_path="/usr/local/nginx/nginx.pid"
#重命名日志文件
mv ${logs_path}access.log ${logs_path}access_$(date -d "yesterday" +"%Y%m%d").log
#向nginx主进程发信号重新打开日志
kill -USR1 `cat ${pid_path}`
这个是切割脚本 nginx的日志比较多,百度出来应该是每30天自动清理一次.但是也有日志比较多查找日志比较繁琐.所以就在网上查了这个脚本.
,第一步就是重命名日志文件,不用担心重命名后nginx找不到日志文件而丢失日志。在你未重新打开原名字的日志文件前,nginx还是会向你重命名的文件写日志,linux是靠文件描述符而不是文件名定位文件。
第二步向nginx主进程发送USR1信号。
nginx主进程接到信号后会从配置文件中读取日志文件名称,重新打开日志文件(以配置文件中的日志名称命名),并以工作进程的用户作为日志文件的所有者。
重新打开日志文件后,nginx主进程会关闭重名的日志文件并通知工作进程使用新打开的日志文件。
工作进程立刻打开新的日志文件并关闭重名名的日志文件。
然后你就可以处理旧的日志文件了
现在想的是把脚本加入更多功能,例如查询几月几日,总访问次数,以及自动清除某时间记录.
明天计划的事情:
继续看以前的日报.
准备小课堂.
把剩下的数据库响应搞了,,看师兄的日报这两个原理是一样的.
遇到的困难,
Nginx错一点字符甚至一个空格就GG了..
网上大多数脚本千篇一律,,,自己又不会写...多搜..
请假回来全身酸痛啊
任务开始时间2017-9-25
任务结束时间2017-10-08
无延期风险
禅道;http://task.ptteng.com/zentao/task-view-10903.html
评论