nginx日志按照天进行分割 
  
  
   时间:2016-09-22 00:59来源:linux.it.net.cn 作者:IT
  
  
   
    
     | 
      由于nginx的日志本身只是支持按照server_name或者大小进行划分,对于习惯了apache的按照一个网站每天一个日志的我来说是不可以接受的,于是从网上找了几个nginx按天分割的方法发现都是互相抄袭的,特别是里面有一个命令是kill -9 `cat nginx.pid`,需要杀掉nginx子进程,我觉得不靠谱。
 
	我忽然想到我以前在做openstack的云存储开发时,对rsyslog的日志进行分割的方法,一用果然好用 
	原理是: 
	1.从一台已经安装好apache的机器上的apache bin目录下把rotatelogs拷贝到本机的/opt/nginx_logs下 
	
		
		
			
				- 
					mkdir -p /opt/nginx_logs
 
				- 
					cp rotatelogs /opt/nginx_logs/
 
				- 
					chmod +x /opt/nginx_logs/rotatelogs
 
			 
		 
	 
 
	2.创建有名管道 
	  
	
		
		
			
				- 
					mkdir /opt/nginx_logs/abc_www/
 
				- 
					mkfifo /opt/nginx_logs/abc_www/access_log
 
			 
		 
	 
	3.在nginx配置文件server中加上  
	
	
		
		
			
				- 
					access_log /opt/nginx_logs/abc_www/access_log;
 
			 
		 
	 
	4.创建日志目录  
	
	
		
		
			
				- 
					mkdir /opt/nginx_logs/abc_www/log/
 
			 
		 
	 
	5.创建日志分割脚本  
	
	
		
		
			
				- 
					[root@localhost nginx_logs]# cat /opt/nginx_logs/abc_www/rotate.sh
 
				- 
					baselogdir=/opt/nginx_logs/abc_www
 
				- 
					rotatelogs=/opt/nginx_logs/rotatelogs
 
				- 
					while [ 1 ]
 
				- 
					do
 
				- 
					echo `date +"%F %T"`" rotatelogs access start"
 
				- 
					$rotatelogs $baselogdir/log/access_%Y%m%d.log 86400 480 < $baselogdir/access_log
 
				- 
					echo `date +"%F %T"`" rotatelogs access stop"
 
				- 
					sleep 1;
 
				- 
					done
 
			 
		 
	 
	6.创建启动日志分割脚本  
	
	
		
		
			
				- 
					[root@localhost nginx_logs]# cat /opt/nginx_logs/abc_www/run.sh
 
				- 
					sh /opt/nginx_logs/abc_www/rotate.sh >> /opt/nginx_logs/abc_www/log/access-rotate.log 2>&1 &
 
			 
		 
	 
	7.最终效果  
      (责任编辑:IT) | 
    
   
 
 
  
  
  
   
   ------分隔线----------------------------