EasyGBS如何解决日志过大打不开的问题?日志分割功能开发分享

在EasyGBS接入设备的限度上,理论上是没有最高限度的,但是根据服务器的运行能力,接入设备过多的话会出现的一些卡顿或者故障。在我们遇到的某些项目现场上,用户接入设备数过多,会导致日志消息频繁打印,日志过大,出现无法打开日志的问题。

日志文件夹logs,系统日志文件****-yyyymmdd.log
**** -error.log、**** -sms-yyyymmdd.log,需要将其按照大小和时间分割,达到****-yyyymmdd.log.1、****-yyyymmdd.log.2这样的效果。

分割之前,打开缓慢,需要疯狂加载:

51.png

随后我们需要实行以上的分割方案,日志打印之前先从配置文件读取出日志文件的单个文件配置大小,在根据当前日志的大小进行判断,是否需要分割。参考代码如下:

if rl != nil {
   return rl
}
alarm := Conf().Section("module")
logSize := alarm.Key("log_size").MustInt(0)
logDir := LogDir()
logFile := filepath.Join(logDir, strings.ToLower(EXEName())+"-%Y%m%d.log")
if logSize > 0 {
   _rl, err := rotatelogs.New(logFile, rotatelogs.WithMaxAge(time.Hour*24*3), rotatelogs.WithRotationSize(int64(logSize*1024*1024)))
   if err == nil {
      rl = _rl
      return rl
   }

分割之后减轻了单个日志的压力,日志则能正常打开:

52.png

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值