NGINX日志切割
2019-03-22 04:20:13来源: podidea.com 阅读 ()
Nginx (“engine x”) 是一个高性能的 HTTP 和反向代理服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,它已经在该站点运行超过两年半了。Igor 将源代码以类BSD许可证的形式发布。
Nginx 超越 Apache 的高性能和稳定性,使得国内使用 Nginx 作为 Web 服务器的网站也越来越多。
上周对Centos中跑的Nginx做了优化,重新设置了图片、JS、CSS的缓存时间,关闭了一些不需要的日志记录等,我侧重讲日志的处理,因为我觉得这个是相当有必要的。刚开始一直认为日志没有必要处理,也就那么几M的东西,当我查看日志大小的时候我瞠目了,我的日志居然有几百M的级别了,当下就决定对日志进行每天必要的处理操作。
为什么要切割日志?一般Nginx安装好后有些人会打开日志记录有些人会关闭日志记录,打开日志记录的人一般都会把架设在Nginx上的所有网站日志都存在同一个文件里(比如我存在access.log日志文件里),这样日积月累所有网站的访问记录就会把日志文件越积越大,当需要查看日志文件的时候一看就是一大串,不方便查找。现在,如果我把每天的日志文件分割开来用相应的日期标识出来这样就大大方便查找了。(我是建议打开日志记录,日志记录里面存放着很多有用的东西。比如:浏览器名称,可以方便你对网站的排版做出调整;IP地址,如果网站收到攻击,你就可以查到那个IP地址。)
下面开始详细步骤:
编写shell程序
某种情况下会设置多个子域名,因此会产生多个日志文件,像我这类喜欢整齐的人会设置多个日志文件,把每个域名的日志都分开放。下面这个shell程序是多域名处理。
下面是示例,对以下三个网站的日志切割(日志文件名自己命名):
http://www.1991s.com 对应日志 blog.log
http://demo.1991s.com 对应日志 demo.log
http://happy.1991s.com 对应日志 happy.log
# !/bin/bash
# 你的日志文件存放目录
logs_path="/home/logs/"
# 日志文件的名字,多个需要空格隔开
logs_names=(blog demo happy)
mkdir -p ${logs_path}$(date -d "yesterday" +"%Y")/$(date -d "yesterday"+"%m")/
num=${#logs_names[@]}
for((i=0;i<num;i++));do
mv ${logs_path}${logs_names[i]}.log ${logs_path}$(date -d "yesterday"+"%Y")/$(date -d "yesterday"+"%m")/${logs_names[i]}_$(date -d "yesterday"+"%Y%m%d").log
done
#pid的位置,自己查找
kill -USR1 `cat /usr/local/nginx/nginx.pid`
设置crontab,每天定时切割
首先需要确定你的服务器有没有安装crontab的服务,输入crontab -e命令,有反应就安装了。
如果没有安装,运行yum install vixie-cron 一键安装。
输入crontab -e命令,输入下面的内容:
1、00 00意思为00分00点,也就是凌晨0点,后面“ * * * ”为“ 日 月 年 ”无需定义
2、” /home/logs/cut_nginx_log.sh “为你的shell的路径。
00 00 * * * /bin/bash /home/logs/cut_nginx_log.sh
OK ! 大功告成,每天的0时就会自动完成日志的切割并存在相应的以日期命名的目录中。
注解:
1.只在Centos下测试,其他linux环境设置略有不同。
2.开启shell程序的775权限,否则可能导致不能运行。
本文采用BY-NC-SA协议进行授权。转载请注明转自:NGINX日志切割
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 微信运营日志这么做!早日升职加薪 2019-04-10
- docker部署nginx php mysql环境实践 2019-04-10
- 微商自媒体日志:创业者的故事 2019-04-10
- 自媒体创业日志:别问有没用 先问你做到极致了么 2019-04-10
- Nginx 配置 SSL 证书 + 搭建 HTTPS 网站教程 2019-04-10
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash