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 太大导致磁盘满的情况比较常见,我先上线弄一下。

 

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

 

 

 

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值