log 文件越来越大导致磁盘满问题

最近由于业务的增加,很多组件中uwsgi 和 nginx 的日志增长的比较快,硬盘空间小的机器资源容易耗尽。导致业务受影响。

因为业务日志都会写到syslog中,而nginx 和uwsgi 一般只放在本地,所以log文件会越来越大。

如下图,

        

解决方案:

一、增加各组件机器的监控,及时发现问题

二、日志定时转存,及时删除旧的日志,防止磁盘出现满的情况

       这里主要说方案二的方法:

 
 

               查了些资料,很多人使用logrotate程序来管理日志,logrotate是日志文件管理工具,可以把旧的文         件删除,并创建新的日志文件,可以根据大小或者时间来转储,这个过程需要依赖于cron

        logrotate 主要配置文件是/etc/logrotate.conf 和 /etc/logrotate.d/*

        下边是配置的一个示例,文件是/etc/logrotate.d/nginx

  1 /usr/local/nginx/logs/*.log {
  2     daily      #每天转储,还可以写weekly和monthly
  3     rotate 3   #指定日志文件删除之前转储的次数,0 指没有备份,3 指保留3 个备份
  4     missingok  #如果指定的目录不存在,logrotate会报错,此项用来关闭报错
  5     notifempty #如果日志为空,则不进行轮转
  6     compress   # 轮转后进行压缩
  7     dateext    #文件名添加YYYYMMDD形式日期
  8     create 644 apache apache # postrotate 前 修改文件权限
  9     postrotate #轮转之后执行的命令
 10         /usr/bin/killall -HUP nginx
 11     endscript
 12 }
 

   具体的含义见后边的注释。

   ps:

         需要保证cron 是启动的

   目前rest api 这台uwsgi log 太大导致磁盘满的情况比较常见,我先上线弄一下。

   其他组件其他同学如果发现类似的问题需要可以按照这个配置来

猜你喜欢

转载自wangleide414.iteye.com/blog/2263138